大家好,我是你的好朋友思创斯。今天说一说vue不支持火狐_火狐浏览器安装本地插件,希望您对编程的造诣更进一步.
某日被告知某个系统在低版本火狐浏览器打开时一片空白,要求尽快修复,于是卸载本机firefox,安排上表现异常的版本firefox 42.0,打开目标系统果然一片空白,然后打开控制台,发现提示如下:
syntaxerror: let is a reserved identifier
是否还在为ide开发工具频繁失效而烦恼,来吧关注以下公众号获取最新激活方式。亲测可用!
【正版授权,激活自己账号】:
【官方授权 正版激活】:

嗯,看提示是低版本还不支持let语法,按照经验转成 var 就行,于是给安排上babel-polyfill再加上各种转换折腾了一上午,无果emmm,,,
嗯,看来还是想当然了(手动捂脸)。于是换个思路,从抛错点入手,从控制台中打开抛错的文件,发现该function有添加”use strict”,暴露给外部的名称为 6062

于是在可疑的几个js文件中查找 6062,发现其被某个name为search的组件引用,再根据其别名 p 判断出该代号为6062的模块其实是fuse.js插件

ps:在6062函数继续往下翻到结尾处,可以发现有一个版本号,在本地源码中直接全局查找该版本号,能更快的发现是fuse.js插件。

search组件中对fuse.js的引用方式如下:
import fuse from 'fuse.js'
node_modules中找到fuse.js的package.json,发现其打包时被引用的是fuse.esm.js

继续查看fuse.esm.js和fuse.esm.min.js文件,发现let和const等es6特性均未被转换,嗯,罪魁祸首终于被找到了。

fuse.js包中有各种规范下处理好的文件

于是换个文件重新引入,该问题完美解决,测试ok。
import fuse from 'fuse.js/dist/fuse.js'
该问题其实并不复杂,对症下药,找到准确的切入点才是关键;拒绝“想当然”,浪费时间可耻,,,嗯~记录一下长长记性。
文章由思创斯整理,转载请注明出处:https://ispacesoft.com/122791.html