vue translate peoject实现在线翻译功能【新手必看】
开始
这是一适合新手练习的小项目,一个在线翻译的demo。
在正式开始前,先??乱幌拢?且晃煌?迅?业慕ㄒ椋?褪遣灰?啃凶榧??奈侍 开始做Vue时我们可能会喜欢拆很多组件出来 但记住组件是为了复用(常见如公共菜单按钮栏等) 如非能够复用的情况其实并不用真的拆出组件来 。
当然,这个项目里因为是练手,所以强行组件化来涉及更多的vue用法。
目录结构
src下新建了两个文件:TranslateForm.vue表单组件和TranslateText.vue翻译结果组件
涉及的语法
- 指令: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实现在线翻译功能,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!
- localstorage和sessionstorage上手使用记录
- jquery升级到新版本报错[jQuery] Cannot read property ‘msie’ of undefined错误的解决方法(转)
- thinphp框架的项目svn重新检出后的必备配置
- 对事件委托绑定click的事件的解绑
- 免杀后门之MSF&Veil-Evasion的完美结合
- 【52ABP实战教程】0.3-- 从GitHub推送代码回VSTS实现双向同步
- css绝对定位如何在不同分辨率下的电脑正常显示定位位置?
- nvm安装node和npm,个人踩坑记录
- clang_intprt_t类型探究
- 学习zepto.js(Hello World)
- JS中函数声明与函数表达式的异同
- [技巧]看我如何通过Weeman+Ettercap拿下路由器管理权限
- 一分钟理清Vue-cli 代码构建步骤。
- 点击图片放大至原始图片大小
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- php微信公众号开发之简答题
- php5.x禁用eval的操作方法
- php微信公众号开发之图片回复
- php微信公众号开发之答题连闯三关
- swoole_process实现进程池的方法示例
- golang实现php里的serialize()和unserialize()序列和反序列方法详解
- keras 实现轻量级网络ShuffleNet教程
- Python应用实现处理excel数据过程解析
- Python实现爬取并分析电商评论
- python中怎么表示空值
- Keras自动下载的数据集/模型存放位置介绍
- Keras 切换后端方式(Theano和TensorFlow)
- python 字符串的驻留机制及优缺点
- php微信公众号开发之翻页查询
- php 中phar包的使用教程详解