vue:引入外部cdn报错 ‘XXX is not defined’ 及事件处理办法

框架:vue-cli(vue脚手架)

例:以cdn引入腾讯防水墙为例

前因:在html的head中引入外部cdn链接,

在vue文件中直接使用,如图

结果:如图报错

解决办法:

1. 在index.html中的head中引入,

2.在webpack.base.conf.js中配置

module.exports = {
  externals: {
    TencentCaptcha: 'TencentCaptcha'
  },
....
}

vue-cli3版本中在 vue.config.js 文件中配置 externals

module.exports = {
  devServer: {
    port: 3200// 端口号配置
  },
  configureWebpack: {
    externals: {
      TencentCaptcha: 'TencentCaptcha'
    }
  }
}

注: vue.config.js 文件要自己创建,vue-cli 3.0 不会自动生成此文件。 此外,修改 vue.config.js 不会触发热加载,也就是修改之后你需要重新 run 一下你的项目,它才能生效。

3.在需要使用的vue文件中引入

import TencentCaptcha from 'TencentCaptcha';

使用

let t = new TencentCaptcha(this.$appid, (rsp) => {
            console.log(rsp);
            t.destroy();
            if (rsp.ret === 0) {
              ...
            } else {
            }
          }, {});
          t.show();

关于腾讯防水墙的文档说明

  • 4
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 7
    评论
### 回答1: vue"xxx is not defined"的意思是“xxx未定义”。这通常是因为在代码中使用了一个未定义的变量或函数。要解决这个问题,需要检查代码中是否存在拼写误或语法误,并确保所有变量和函数都已经定义。 ### 回答2: 在Vue的开发过程中,遇到xxx is not defined,通常有以下几种情况: 1. 没有引入需要使用的变量或组件。例如在使用组件时,没有使用import语句引入该组件;或者在使用变量时,没有在data中定义该变量,导致出现xxx is not defined。 2. 变量名、函数名等书写误。在Vue中,变量名、函数名等书写误也会导致。这种情况下,我们需要检查代码中的拼写误,确保正确使用变量名或函数名。 3. 生命周期钩子函数用法误。Vue的生命周期钩子函数包括created、mounted、updated、destroyed等,如果在使用这些钩子函数时出现了xxx is not defined,通常是因为钩子函数的使用方法误或者没有正确命名这些函数。 4. 组件props传递参数误。Vue组件间的通信可以通过传递props来完成,如果在传递参数时出现xxx is not defined,通常是因为props定义出或者父组件传递参数时格式出导致的。 如果遇到了xxx is not defined,可以通过以上几种情况进行排查,找到出的原因并进行修正。同时,在编写代码时也应该注意规范与细节,减少出的可能性。 ### 回答3: Vue"xxx is not defined"是指在Vue的代码中,引用了不被定义的变量或函数。这个误常常出现在Vue项目中,它会阻止Vue的正常运行,导致Vue程序无法进行下去。 对于这个问题的解决方法如下: 1.检查引用的变量或函数是否存在:在JavaScript中,如果想要引用某个变量或函数,必须要明确地定义,并赋值。如果这个变量或函数没有被定义,就会出现"not defined"的误提示。我们需要检查Vue的代码中是否出现了这种情况,如果有,则需要重新定义变量或函数,或者引入对应的JS文件。 2.检查代码顺序:Vue代码通常分为三部分:HTML代码、JavaScript代码和CSS代码。在Vue的JavaScript代码中,引用的变量或函数必须在调用之前被定义。如果JavaScript代码的顺序不正确,就会出现"not defined"的误提示。检查代码的顺序是否正确,确保变量或函数已经被定义。 3.使用Vue提供的API:Vue提供了一些API可以帮助我们解决"not defined"的误提示。比如:$emit、$refs、$mount等。这些API可以帮助我们引用Vue组件中的变量或方法,确保代码运行的正确性。 4.查看浏览器控制台:在进行Vue开发的时候,我们需要经常查看浏览器控制台,以了解Vue的运行情况和误。当出现"not defined"的误提示时,我们需要查看浏览器控制台的误信息,找到误的位置和原因,然后进行调试和修复。 总之,"xxx is not defined"的误提示是Vue中常见的问题,涉及到变量或函数的定义、代码顺序、API的使用和浏览器控制台的调试。我们需要仔细检查代码,确保变量或函数被正确定义,并使用Vue提供的API和浏览器控制台进行调试和修复。
评论 7
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Mosowe

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值