继续浏览精彩内容
慕课网APP
程序员的梦工厂
打开
继续
感谢您的支持,我会继续努力的
赞赏金额会直接到老师账户
将二维码发送给自己后长按识别
微信支付
支付宝支付

Vue 新手小项目 vue-translate-peoject 在线翻译功能

30秒到达战场
关注TA
已关注
手记 415
粉丝 95
获赞 569

开始

这是一适合新手练习的小项目,一个在线翻译的demo。
https://img4.mukewang.com/5af8118c0001238607570330.jpg
在正式开始前,先啰嗦一下,是一位网友给我的建议,就是不要强行组件化的问题 开始做Vue时我们可能会喜欢拆很多组件出来 但记住组件是为了复用(常见如公共菜单按钮栏等) 如非能够复用的情况其实并不用真的拆出组件来 。
当然,这个项目里因为是练手,所以强行组件化来涉及更多的vue用法。

目录结构

src下新建了两个文件:TranslateForm.vue表单组件和TranslateText.vue翻译结果组件
https://img1.mukewang.com/5af8119700010d4203010185.jpg

涉及的语法

  • 指令: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接收父组件传值来使用

作者:ZONE_98F                            
来源:https://segmentfault.com/a/1190000014834742?utm_source=channel-hottest


打开App,阅读手记
2人推荐
发表评论
随时随地看视频慕课网APP