vue translate peoject实现在线翻译功能【新手必看】


Posted in Javascript onJune 07, 2018

 开始

这是一适合新手练习的小项目,一个在线翻译的demo。

vue translate peoject实现在线翻译功能【新手必看】

在正式开始前,先??乱幌拢?且晃煌?迅?业慕ㄒ椋?褪遣灰?啃凶榧??奈侍 开始做Vue时我们可能会喜欢拆很多组件出来 但记住组件是为了复用(常见如公共菜单按钮栏等) 如非能够复用的情况其实并不用真的拆出组件来 。

当然,这个项目里因为是练手,所以强行组件化来涉及更多的vue用法。

目录结构

src下新建了两个文件:TranslateForm.vue表单组件和TranslateText.vue翻译结果组件

vue translate peoject实现在线翻译功能【新手必看】

涉及的语法

  • 指令:v-model,v-on,v-bind
  • 父子组件通信:$emit,props
  • 动态更新数据:vm.$set
  • 翻译服务的API,我这里用的是有道翻译的api

——————————————————————————————分割线————————————————————————

TranslateForm.vue
<template>
 <div>
 <!--加上页面修饰符,提交时就不回再重载页面-->
 <form v-on:submit.prevent="formSubmit">
  <input type="text" v-model="text" placeholder="输入需要翻译的内容"/>
  <select v-model="to">
  <option value ="en">英文</option>
  <option value ="ko">韩文</option>
  <option value ="fr">法文</option>
  <option value ="ru">俄文</option>
  </select>
  <input type="submit" value="翻译"/>
 </form>
 </div>
</template>
<script>
export default {
 name: 'TranslateForm',
 data: function () {
 return {
  text: '',
  to: 'en'
 }
 },
 methods: {
 formSubmit: function () {
  this.$emit('formSubmit', this.text, this.to)
 }
 }
}
</script>
<style></style>

这里没啥好说的,text和to两个变量分别是要翻译的文字和翻译语言的选项,this.$emit把数据传给父组件使用

根组件APP

<template>
 <div id="app">
 <h2>简单翻译</h2><span>简单/易用/便捷</span>
 <TranslateForm v-on:formSubmit="textTranslate"></TranslateForm>
 <TranslateText :translated-text="translatedText"></TranslateText>
 </div>
</template>
<script>
import TranslateForm from './components/TranslateForm.vue'
import TranslateText from './components/TranslateText.vue'
import md5 from 'blueimp-md5'
import $ from 'jquery'

export default {
 name: 'App',
 data: function () {
 return {
  translatedText: '2',
  appKey: '47bb6e424790df89',
  key: 'NH2VxBadIlKlT2b2qjxaSu221dSC78Ew',
  salt: (new Date()).getTime(),
  from: '',
  to: 'en'
 }
 },
 components: {
 TranslateForm, TranslateText
 },
 methods: {
 textTranslate: function (text, to) {
  let vm = this
  $.ajax({
  url: 'http://openapi.youdao.com/api',
  type: 'post',
  dataType: 'jsonp',
  data: {
   q: text,
   appKey: this.appKey,
   salt: this.salt,
   from: this.from,
   to: to,
   sign: md5(this.appKey + text + this.salt + this.key)
  },
  success: function (data) {
   vm.$set(vm.$data, 'translatedText', data.translation[0])
  }
  })
 }
 }
}
</script>
<style>
 #app {
 font-family: 'Avenir', Helvetica, Arial, sans-serif;
 -webkit-font-smoothing: antialiased;
 -moz-osx-font-smoothing: grayscale;
 text-align: center;
 color: #2c3e50;
 margin-top: 60px;
 }
</style>

1、父组件拿到子组件传来的数据后开始通过api来请求数据
2、我用的是有道api http://ai.youdao.com/login.s api文档里对于api的使用已经很详细了,我在这里是第一次使用api,没觉得难
3、需要自己安装两个依赖:一个是jquery由于ajax请求api,一个是blueimp-md5在请求api时会用到里面的md5()
4、用vue.set将得到的结果绑定到translatedText这个变量,在这一步的时候我踩了两个坑

第一个坑:习惯了以前的写法,直接就这样给变量赋值,结果变量的值并未改变,这时我还不知到有Vue.set这个语法,后面百度才知道的(不认真看文档的下场)

success: function (data) {
   this.translatedText = data.translation[0]
   console.log(this.translatedText)
  }

第二个坑:照着文档来写,然后报错了:this.$set is not a function,这里报错是因为success这个函数里的this指向的不是当前的VueModel     

success: function (data) {
   this.$set(this.$data, 'translatedText', data.translation[0])
  }

所以我在前面定义了一个vm变量来充当当前Model,然后就不报错了。

TranslateText.vue
<template>
 <div id="TranslateText">
 <p>{{translatedText}}</p>
 </div>
</template>
<script>
export default {
 name: 'TranslateText',
 props: [
 'translatedText'
 ]
}
</script>
<style></style>

props接收父组件传值来使用

最后

这个文章我自己看了一下,写的确实不好,许多地方不通顺,希望大家多多包涵

代码我上传到github了 https://github.com/Zone-F/vue... (没加样式)

以上所述是小编给大家介绍的vue translate peoject实现在线翻译功能,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
jquery中邮箱地址 URL网站地址正则验证实例代码
Sep 15 Javascript
jquery获取一个元素下面相同子元素的个数代码
Jul 31 Javascript
JavaScript实现select添加option
Jul 03 Javascript
基于replaceChild制作简单的吞噬特效
Sep 21 Javascript
浅谈js数据类型判断与数组判断
Aug 29 Javascript
JS数字千分位格式化实现方法总结
Dec 16 Javascript
AngularJS实用基础知识_入门必备篇(推荐)
Jul 10 Javascript
Angular父子组件通过服务传参的示例方法
Oct 31 Javascript
vue回到顶部监听滚动事件详解
Aug 02 Javascript
微信小程序分包加载代码实现方法详解
Sep 23 Javascript
vue 更改连接后台的api示例
Nov 11 Javascript
Postman参数化实现过程及原理解析
Aug 13 Javascript
JavaScript 正则命名分组【推荐】
Jun 07 #Javascript
详解create-react-app 自定义 eslint 配置
Jun 07 #Javascript
vue.js实现标签页切换效果
Jun 07 #Javascript
js数组去重的N种方法(小结)
Jun 07 #Javascript
vue+axios新手实践实现登陆的示例代码
Jun 06 #Javascript
vue2.0实现音乐/视频播放进度条组件
Jun 06 #Javascript
vue实现简单loading进度条
Jun 06 #Javascript
You might like
浅析HTTP消息头网页缓存控制以及header常用指令介绍
2013/06/28 PHP
文件上传之SWFUpload插件(代码)
2015/07/30 PHP
PHP会员找回密码功能的简单实现
2016/09/05 PHP
php的4种常用运行方式详解
2016/12/22 PHP
Ajax中的JSON格式与php传输过程全面解析
2017/11/14 PHP
从JavaScript的函数重名看其初始化方式
2007/03/08 Javascript
用js实现输入提示(自动完成)的实例代码
2013/06/14 Javascript
jquery.ajax的url中传递中文乱码问题的解决方法
2014/02/07 Javascript
jQuery实现单击和鼠标感应事件
2015/02/01 Javascript
论Bootstrap3和Foundation5网格系统的异同
2016/05/16 Javascript
springMVC结合AjaxForm上传文件
2016/07/12 Javascript
js实现canvas保存图片为png格式并下载到本地的方法
2017/08/31 Javascript
详解nodejs中express搭建权限管理系统
2017/09/15 NodeJs
React Native 自定义下拉刷新上拉加载的列表的示例
2018/03/01 Javascript
layui select动态添加option的实例
2018/03/07 Javascript
基于elementUI使用v-model实现经纬度输入的vue组件
2019/05/12 Javascript
js里面的变量范围分享
2020/07/18 Javascript
Vue 电商后台管理项目阶段性总结(推荐)
2020/08/22 Javascript
Python使用urllib2获取网络资源实例讲解
2013/12/02 Python
python搭建虚拟环境的步骤详解
2016/09/27 Python
python xlsxwriter库生成图表的应用示例
2018/03/16 Python
python xlsxwriter创建excel图表的方法
2018/06/11 Python
tensorflow使用神经网络实现mnist分类
2018/09/08 Python
解决Python运行文件出现out of memory框的问题
2018/12/03 Python
python jenkins 打包构建代码的示例代码
2019/11/29 Python
关于Tensorflow分布式并行策略
2020/02/03 Python
matplotlib 使用 plt.savefig() 输出图片去除旁边的空白区域
2021/01/05 Python
美国最灵活的移动提供商:Tello
2017/07/18 全球购物
JSP和Servlet有哪些相同点和不同点,他们之间的联系是什么?
2015/10/22 面试题
职专应届生求职信
2013/11/16 职场文书
项目合作意向书范本
2014/04/01 职场文书
房地产活动策划方案
2014/05/14 职场文书
汉语言文学毕业求职信
2014/07/17 职场文书
2015元旦晚会主持人开场白+结束语
2014/12/14 职场文书
Jpa Specification如何实现and和or同时使用查询
2021/11/23 Java/Android
Ubuntu安装Mysql+启用远程连接的完整过程
2022/06/21 Servers