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

 开始

这是一适合新手练习的小项目,一个在线翻译的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实现在线翻译功能,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!

© 版权声明
THE END
喜欢就支持一下吧
点赞0 分享
评论 抢沙发

请登录后发表评论

    暂无评论内容