位置: IT常识 - 正文

Vue组件中如何引入外部的js文件(vue 组件调用)

编辑:rootadmin
Vue组件中如何引入外部的js文件

推荐整理分享Vue组件中如何引入外部的js文件(vue 组件调用),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:vue怎么使用组件,vue引用子组件,vue 组件调用,vue引入插件方法,vue如何引用组件,vue引用子组件,vue引用子组件,vue怎么使用组件,内容如对您有帮助,希望把文章链接给更多的朋友!

https://zhuanlan.zhihu.com/p/379504188

背景 在Vue中,通常我们引入一个js插件都是使用npm 方式下载然后import使用的。但是我现在本地有了js文件或者是一个远程js文件链接,我不想使用npm install xxx 的方式,有什么办法吗?

方式一 简单粗暴,直接在Vue项目的index.html 中使用全局的方式引入,比如:

<title>测评</title><link type="text/css" href="//at.alicdn.com/t/font_43459_d124thd3lgu.css" rel="stylesheet">{{ie9 /resources/js/history.min.js}}

// 暴力引入 缺点:不使用该js插件的组件也会加载,而我只想在某个Vue组件中使用该js插件。

方式二 如果是下载到本地的静态文件,可以使用import 的方式导入。

import { xxx } from ‘…/js/xxx.js’ //注意路径 缺点:下载的本地静态文件才可以,远程js文件不可以。

方式三 在Vue组件加载完后,手动操作DOM插入js插件。

export default { mounted() { let script = document.createElement(‘script’); script.type = ‘text/javascript’; script.src = ‘你的js文件地址’; document.body.appendChild(script); }, } 该方式直接操作DOM,只在当前组件插入js插件。

方式四 使用render方法。

Vue组件中如何引入外部的js文件(vue 组件调用)

export default { components: { ‘xxx-js’: { render(createElement) { return createElement( ‘script’, { attrs: { type: ‘text/javascript’, src: ‘你的js文件地址’, }, }, ); }, }, }, } // 使用 在页面中调用 使用的时候,使用 在页面中调用。

方式五 高阶玩法。将方式三包装成一个js插件,使用 Promise,js加载成功,调用resolve,js加载失败,调用reject。

function loadJs(src) { return new Promise((resolve,reject)=>{ let script = document.createElement(‘script’); script.type = “text/javascript”; script.src= src; document.body.appendChild(script);

script.onload = ()=>{ resolve();}script.onerror = ()=>{ reject();}

}) }

export default loadJs 使用的时候:

import loadJs from ‘./loadJs’

export default { mounted(){ loadJs(‘http://api.map.baidu.com/xxx.js’).then(()=>{ // 加载成功,进行后续操作 }) } } 方式六 更高阶方式。可以动态替换要加载的js文件。

包装一个importJs.js 插件。

// 导入外部js import Vue from ‘vue’

Vue.component(‘remote-script’, { render: function (createElement) { var self = this; return createElement(‘script’, { attrs: { type: ‘text/javascript’, src: this.src }, on: { load: function (event) { self.KaTeX parse error: Expected 'EOF', got '}' at position 30: …vent); }̲, error…emit(‘error’, event); }, readystatechange: function (event) { if (this.readyState == ‘complete’) { self.$emit(‘load’, event); } } } }); }, props: { src: { type: String, required: true } } }); 使用方式:

// 引入 import ‘common/importJs.js’

// html使用的地方

(完)

本文链接地址:https://www.jiuchutong.com/zhishi/298535.html 转载请保留说明!

上一篇:Vue3 京东到家项目实战第一篇(首页及登录功能开发) 进阶式掌握vue3完整知识体系(京东到家的物流模式)

下一篇:Vue|获取表单数据(vue获取value值)

  • 小规模纳税人税收优惠2023
  • 固定资产清理亏损的账务处理
  • 制造费用科目一定无余额
  • 工资怎么扣费
  • 增值税报税后多久缴纳期限
  • 增值税改革后增值税申报表怎么填写
  • 调研费包括哪些科目
  • 转让房地产未完工项目增值税发票如何处理?
  • 超额投资是什么意思
  • 购销行为的帐务处理如何做?
  • 借款转资本公积怎么算税
  • 质量问题扣款账务处理
  • 物业公司收取电费加价依据
  • 城建税和教育费附加计入什么科目
  • 企业所得税期末贷方余额怎么办
  • 上报汇总和抄报是一个意思吗
  • 第三方支付模式的交流流程
  • 投资收益税前扣除标准
  • 房地产开发企业取得的土地使用权用于建造
  • 企业自用房产出售怎么交税
  • 公司注销银行账户流程
  • 应付暂估应在何时申报
  • 计提固定资产减值准备会计科目
  • 腾讯手游助手怎么把游戏放到桌面
  • 会计中如何区分借方和贷方
  • 免税出口样品收多少税
  • 个人所得税专项扣除子女教育标准
  • 非正常损失运输费进项税额如何转出
  • 商品结转成本后怎么做账
  • uniapp自定义下拉刷新上拉加载
  • gba是什么文件
  • 房屋装修各项费用比例
  • 中央公园纽约的历史背景
  • php二维数组按某个键值排序
  • 工会经费计提基数包括绩效工资吗
  • php redis秒杀高并发解决方案
  • nodejs如何使用
  • CV攻城狮入门VIT(vision transformer)之旅——VIT原理详解篇
  • 金融资产减值迹象
  • 结转成本的会计科目
  • 非营利组织会计就是用于确认、计量
  • mysql数据库高可用方案
  • 减免增值税记账
  • mysql数据控制语句
  • 法人向公司账户打款合法吗
  • 社保缴费基数怎么算
  • 餐饮管理公司如何收取管理费
  • 销售提成如何入账
  • 应税消费品含税吗
  • 用现金券付房租违法吗
  • 材料暂估入库的账务处理
  • 营改增后房租发票可以抵扣吗
  • 如何解决私账流失问题
  • 其他应收款借方负数代表什么意思
  • 营改增之后账务怎么处理
  • 公司对公账户的钱怎么取出来
  • 其他费用包括哪些内容
  • 资产减值损失是费用类科目吗
  • mysql 存过
  • linux系统中cron命令
  • ubuntu 14.10
  • FreeBSD5.4之apache-2.0.54+php+ZendOptimizer简单安装、设置
  • 苹果mac系统怎么用
  • windows8装 .NET 3.5 时出现0x800F081F错误解决方法
  • win10怎么禁用device/credential guard
  • win10局域网无法上网
  • linux有两个ip
  • opengll
  • ExtJS4如何自动生成控制grid的列显示、隐藏的checkbox
  • perl中打开文件
  • unity单选
  • android 样式
  • 自动重启服务脚本
  • javascript概述及作用
  • 深圳国家税务局赵雨婷处长
  • 稽查局是税务局的派出机构还是内设机构
  • 四川增值税发票图片
  • 小型贸易公司怎么赚钱
  • 新疆自治区国税局郑志全
  • 北京市生育津贴发放标准
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设