时间:2021-05-26
开始
这是一适合新手练习的小项目,一个在线翻译的demo。
在正式开始前,先啰嗦一下,是一位网友给我的建议,就是不要强行组件化的问题 开始做Vue时我们可能会喜欢拆很多组件出来 但记住组件是为了复用(常见如公共菜单按钮栏等) 如非能够复用的情况其实并不用真的拆出组件来 。
当然,这个项目里因为是练手,所以强行组件化来涉及更多的vue用法。
目录结构
src下新建了两个文件:TranslateForm.vue表单组件和TranslateText.vue翻译结果组件
涉及的语法
——————————————————————————————分割线————————————————————————
这里没啥好说的,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实现在线翻译功能,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
本文实例为大家分享了vue实现在线翻译功能的具体代码,供大家参考,具体内容如下最终效果:APP.vue在线翻译简单/易用/方便importTranslateFo
Word2003具有在线翻译功能,用户借助Word在线翻译功能在多种语言之间进行翻译。例如中文与英文、日文、法文、西班牙文的互译都可以实现。1.启用翻译功能在W
利用搜狗输入法可以实现在线翻译,并且可以实现“中文—英文”,“中文—日文”,&ldquo
tkinter的功能是如此强大,竟然还能做翻译软件。当然是在线的,我发现有一个quicktranslate模块,可以提供在线翻译功能,相当于提供了一个翻译的接口
本文实例为大家分享了python实现在线翻译的具体代码,供大家参考,具体内容如下具体效果请看图代码:importurllib.requestimporturll