H5页面跳转微信小程序时:wx.miniProgram.navigateTo 报错 ‘wx‘ is not defined no-undef

有一个功能,需要从H5页面跳转到微信小程序,查了微信官方文档:只需要引入js文件,然后直接使用即可:

1:引用:

 当然也可以下载下来直接引用项目具体位置的js文件

2: 使用:

然后一直报错: Line 161:  'wx' is not defined  no-undef

查了网上的一些解决方法,基本是以下几种(最好用的在最后):

1:eslint校验配置去掉对wx这个变量no-undef的校验

解决方法:在 .eslintrc.js 文件里加入以下内容,就不会报错了

module.exports = {
    // 省略其他配置...
    globals: {
        wx: true
    }
}

2:禁用eslint的no-undef校验

在.eslintrc.js中rules的规则如下:

rules: {
    "no-undef": "off"
}
规则值:
"off"或者0     //关闭检测规则
"warn"或者1    //打开并把打开的检测规则作为警告(不影响退出代码)
"error"或者2   //打开并把检测规则作为一个错误(退出代码触发时为1)
————————————————
"no-undef": 1,//不能有未定义的变量

3:定义全局变量

修改vue.config.js文件:
在configureWebpack下的externals中定义全局变量即可。
参考如下:

configureWebpack: {
  // 全局常量定义
  externals: {
    X2JS: 'X2JS'
  }
},
 

4:直接import使用
例如将原本<script>的引入方式:
<script language="javascript" src="/static/js/xml2json.js" ignore>
改为import导入具体位置的文件:
import X2JS from '@/assets/js/xml2json.js'
照常使用,就无需定义全局变量了!
 

5:项目没有eslintrc.js文件,但是可以在package.json中配置eslint规则
在这里插入图片描述
在rules规则下,添加"no-undef": "off"即可

 

但我的工程中没有eslintrc.js文件,改了package.json也没生效,最后找到一种最简单有效的方法,在当前报错文件的最上面加一行代码:

/* eslint-disable */

就像这样:

 

 禁用当前页面的eslint检查,亲测好用

收工

 

评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

学编程的司马光

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

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

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

打赏作者

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

抵扣说明:

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

余额充值