Flask接口签名sign原理与实例代码浅析
540
2023-01-29
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
export default {
name: 'TranslateForm',
data: function () {
return {
text: '',
to: 'en'
}
},
methods: {
formSubmit: function () {
this.$emit('formSubmit', this.text, this.to)
}
}
}
这里没啥好说的,text和to两个变量分别是要翻译的文字和翻译语言的选项,this.$emit把数据传给父组件使用
根组件APP
import TranslatDCptrkVHBeForm 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])
}
})
}
}
}
#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;
}
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(DCptrkVHBthis.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
{{translatedText}}
export default {
name: 'TranslateText',
props: [
'translatedText'
]
}
props接收父组件传值来使用
最后
这个文章我自己看了一下,写的确实不好,许多地方不通顺,希望大家多多包涵
代码我上传到github了 https://github.com/Zone-F/vue... (没加样式)
以上所述是给大家介绍的vue translate peoject实现在线翻译功能,希望对大家有所帮助,如果大家有任何疑问请给我留言,会及时回复大家的。在此也非常感谢大家对我们网站的支持!
版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。
发表评论
暂时没有评论,来抢沙发吧~