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 相关文章推荐
Javascript中的this绑定介绍
Sep 22 Javascript
javascript+canvas制作九宫格小程序
Dec 28 Javascript
3种js实现string的substring方法
Nov 09 Javascript
Jquery Mobile 自定义按钮图标
Nov 18 Javascript
JS 面向对象之继承---多种组合继承详解
Jul 10 Javascript
jQuery UI 实例讲解 - 日期选择器(Datepicker)
Sep 18 jQuery
微信小程序使用slider设置数据值及switch开关组件功能【附源码下载】
Dec 09 Javascript
使用mock.js随机数据和使用express输出json接口的实现方法
Jan 07 Javascript
手把手教你vue-cli单页到多页应用的方法
May 31 Javascript
vue中组件的3种使用方式详解
Mar 23 Javascript
JavaScript中将值转换为字符串的五种方法总结
Jun 06 Javascript
element-ui 实现响应式导航栏的示例代码
May 08 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
destoon安装出现Internal Server Error的解决方法
2014/06/21 PHP
深入浅析PHP无限极分类的案例教程
2016/05/09 PHP
Symfony2针对输入时间进行查询的方法分析
2017/06/28 PHP
更快的异步执行(setTimeout多浏览器)
2014/08/12 Javascript
jQuery实现仿百度帖吧头部固定导航效果
2015/08/07 Javascript
js 中文汉字转Unicode、Unicode转中文汉字、ASCII转换Unicode、Unicode转换ASCII、中文转换
2016/12/06 Javascript
原生JS实现圣旨卷轴展开效果
2017/03/06 Javascript
Angular 2.0+ 的数据绑定的实现示例
2017/08/09 Javascript
JS获取日期的方法实例【昨天,今天,明天,前n天,后n天的日期】
2017/09/28 Javascript
记一次webapck4 配置文件无效的解决历程
2018/09/19 Javascript
Node.js EventEmmitter事件监听器用法实例分析
2019/01/07 Javascript
JavaScript刷新页面的几种方法总结
2019/03/28 Javascript
angular6开发steps步骤条组件
2019/07/04 Javascript
Python实现快速排序和插入排序算法及自定义排序的示例
2016/02/16 Python
Python获取当前页面内所有链接的四种方法对比分析
2017/08/19 Python
详解python中的 is 操作符
2017/12/26 Python
tensorflow 使用flags定义命令行参数的方法
2018/04/23 Python
Python绘制堆叠柱状图的实例
2019/07/09 Python
如何使用Flask-Migrate拓展数据库表结构
2019/07/24 Python
基于python3的socket聊天编程
2020/02/17 Python
Matplotlib使用字符串代替变量绘制散点图的方法
2020/02/17 Python
Android Q之气泡弹窗的实现示例
2020/06/23 Python
获取CSDN文章内容并转换为markdown文本的python
2020/09/06 Python
如何通过python检查文件是否被占用
2020/12/18 Python
AmazeUI 输入框组的示例代码
2020/08/14 HTML / CSS
allbeauty美国:英国在线美容店
2019/03/11 全球购物
一些Unix笔试题和面试题
2012/09/25 面试题
教师自荐信范文
2013/12/09 职场文书
《伯牙绝弦》教学反思
2014/03/02 职场文书
大班亲子运动会方案
2014/06/10 职场文书
我的中国梦演讲稿1000字
2014/08/19 职场文书
老公保证书怎么写
2015/02/26 职场文书
培根随笔读书笔记
2015/07/01 职场文书
导游词之北京明十三陵
2019/10/28 职场文书
教你怎么用python爬取爱奇艺热门电影
2021/05/20 Python
Redis特殊数据类型bitmap位图
2022/06/01 Redis