Vue引入远程JS文件
2017-02-19 08:44
411 查看
问题
最近在使用 Vue 做东西,用到钉钉扫描登录的功能,这里需要引入远程的 js 文件,因为 Vue 的方式跟之前的不太一样,又不想把文件下载到本地应用,找了一下解决的方法,貌似都需要引入第三方的库,最后找到了解决方案,分享之。
思路
一开始的思路是在 Vue 加载完 Dom 之后(mounted),使用 JavaScript 脚本在 body 中插入远程的脚本文件。
后来发现了 Vue 的
createElement方法,简单的封装一个组件解决问题。
解决方法
第一版代码(直接在操作 Dom )如下:export default { mounted() { const s = document.createElement('script'); s.type = 'text/javascript'; s.src = 'https://g.alicdn.com/dingding/dinglogin/0.0.2/ddLogin.js'; document.body.appendChild(s); }, }
使用
createElement方法:
export default { components: { 'dingtalk': { render(createElement) { return createElement( 'script', { attrs: { type: 'text/javascript', src: 'https://g.alicdn.com/dingding/dinglogin/0.0.2/ddLogin.js', }, }, ); }, }, }, } // 使用 <dingtalk></dingtalk> 在页面中调用
终极方案
通过封装一个组件 remote-js实现:
export default { components: { 'remote-js': { render(createElement) { return createElement('script', { attrs: { type: 'text/javascript', src: this.src }}); }, props: { src: { type: String, required: true }, }, }, }, }
使用方法:
<remote-js src="https://g.alicdn.com/dingding/dinglogin/0.0.2/ddLogin.js"></remote-js>
因为刚开始学习 Vue 有什么问题欢迎大家指出,大家一起讨论讨论。
参考资料
Vue - Render Functions
相关文章推荐
- vue中引入远程的js文件
- Vue中如何引入远程JS文件?
- Vue引入远程JS文件
- Vue如何引入远程JS文件
- vue文件中引入外部js
- vue如何引入icon小图标的js文件
- 关于在vue中引入jquery或js文件
- vue脚手架使用swiper /引入js文件/引入css文件
- Vue项目中引入外部文件的方法(css、js、less)
- Android studio 引入 weex 中由.vue打包的.js文件,ReferenceError: Vue is not defined错误
- Vue.js项目引入less文件报错解决
- vue.js在laravel框架模板文件中引入失败问题
- Vue-cli项目中引入外部/第三方css/js/less文件具体步骤
- vue引入自己写的js文件
- vue引入swiper vue使用swiper vue脚手架使用swiper /引入js文件/引入css文件
- vue项目中引入外部css以及js文件的方法
- (vue.js)vue-cli构建,scss文件引入本地css意外报错
- vue-cli项目中单文件组件引入bootstrap.js异常的解决方案
- 学习vue-cli时需要引入外部js库文件(如jquery)的问题,百度后解决了,再次备忘一下
- Vue 模块引入远程Js