账号密码登录
微信安全登录
微信扫描二维码登录

登录后绑定QQ、微信即可实现信息互通

手机验证码登录
找回密码返回
邮箱找回 手机找回
注册账号返回
其他登录方式
分享
  • 收藏
    X
    通过script标签引入js文件的方式怎么替换成import引入的方式?
    46
    0

    有个项目为了实现某个功能,我需要引入viz.js文件
    于是我将viz.js放在static目录下,然后在index.html中通过script标签引入。

    let head = document.getElementsByTagName('head')[0];
    createElement('script', head, { src: "static/resource/plugin/viz.js" })
    
    function createElement(tag, target, attrs){
      let element = document.createElement(tag)
      if(attrs && typeof attrs === 'object'){
        for(let key in attrs){
          element.setAtrribute ? element.setAtrribute(key, attrs[key]) : element[key] = attrs[key]
        }
      }
      target.append(element)
    }

    该方式能让我项目正常运行,但是当我将项目封装成框架作为npm模块包发布,在测试中发现,因为新项目中的static是空文件夹,所以会导致该方式错误,引入的js不存在,报错unexpected token <
    尝试的解决措施:
    ①把模块包中的static文件夹替换新项目,可行,但觉得这种方式不太合理,不方便
    ②修改script标签的引用路径为相对路径createElement('script', head, { src: "../../static/resource/plugin/viz.js" })但在依旧被浏览器识别为static/resource/plugin/viz.js,不可取
    ③通过npm方式引入viz,npm i viz.js然后在某处js文件中import 'viz'或是import Viz from 'viz',都报错,在GitHub上viz.js的项目并没有找到使用说明,放弃该方式
    ④通过import的方式引入本地的viz.js文件或是将viz.js放在src文件夹中,报语法错误,提示有ts的语法,导致编译过程报错,无法启动项目
    ⑤修改script标签路径为https://cdn.bootcss.com/viz.j...,可行,但线上引入有些不保险

    框架的项目地址:https://gitee.com/g2333/data_...

    0
    打赏
    收藏
    点击回答
    您的回答被采纳后将获得:提问者悬赏的 11 元积分
        全部回答
    • 0
    更多回答
    扫一扫访问手机版

    回答动态

    师傅被妖怪抓走了:发布了悬赏问题火爆全网的“元宇宙”到底是什么?预计能赚取 1积分收益
    酒后略带风情:发布了悬赏问题Android内存中Graphics与Code占用过高预计能赚取 10积分收益
    扛起拖把扫天下:发布了悬赏问题typescript如何导出接口配置?求解,谢谢!预计能赚取 10积分收益
    发布了悬赏问题Vue 如何改变返回页面的路径?如让B页面只能返回到A页面.预计能赚取 11积分收益
    发布了悬赏问题vue H5移动端;底部bottom固定定位,安卓弹起键盘导致页面变形如何解决?预计能赚取 10积分收益
    发布了悬赏问题请问为什么tomcat8.5 GET请求中文正常,POST请求还需要设置UTF-8.预计能赚取 10积分收益
    发布了悬赏问题vue2.5+ts创建以及引入jq的方法预计能赚取 11积分收益
    情场浪女:发布了悬赏问题import ggplot时报错module 'pandas' has no attribute 'tslib'预计能赚取 10积分收益
    见心书画许老师18753375161:发布了悬赏问题echarts3 legend禁止点击事件,允许悬浮事件预计能赚取 11积分收益
    aa_92cb0bd09f:发布了悬赏问题codewar上的一个问题预计能赚取 11积分收益