zoukankan      html  css  js  c++  java
  • 如何通过webpack和node来实现多个静态页面html,多个入口,能打包能热加载开发环境调试

    demo已经传到了github,地址: https://github.com/13476075014/04.node-vue-project/tree/master/03.singlewebpack

    ## 一:demo目的:

    如何通过webpack和node来实现多个静态页面html,多个入口,能打包,能热加载,能开发环境调试,能生成dist里面的线上需要文件;

    ## 二:demo难点:

    1.每个html都需要引入多个静态js,这时候配置入口文件就有问题?
      解决思路:把html的多个js,或者css的需要引入的静态文件,都通过一个js先引入进去,到时候直接引入这一个js就可以了。
      
    2.如何动态获取到每个html的入口js作为webpack打包的入口文件?
      解决思路:通过glob这个插件来获取所有需要作为入口文件js的文件名,成为一个数组,然后循环这个数组,去拼接json的key:filename,value:filepath,这样就可以获取到完整的入口文件。
    3.如何能在开发环境热加载这些打包后的静态文件,能实时刷新改动的内容?
      解决思路:不能用webpack-dev-server,因为现在是多个单页需要访问,用这个插件用到的"webpack-dev-middleware": "^1.12.2(这个版本过高会报错我这边。。,这个版本是可以的)" 和 "webpack-hot-middleware": "^2.25.0",这两个插件来实现开发环境,读取内存里面的打包完的文件,然后通过名字匹配node的路由来进行访问;

    ## 三:目录结构

     

    dist -- 打包后的文件存放地址,正式环境只需要这个里面的文件就可以了;
    public -- 静态资源 图片,css,js 的存放地址;
    public --> js --> bundle 这个文件夹是存放一个静态html对应一个js,且名字要和html的名字一致;
    views -- 静态html的文件夹;
    main.js - node启动项目入口js;
    webpack.config.js -- 是webpack打包的入口

    ## 项目启动

    先 npm install 安装包;
    然后 本地开发运行  npm start;
    发布到线上就使用 npm run prodbuild;

    具体运行代码方式在 package.json里面 :
     "scripts": {
        "start": "cross-env NODE_ENV=development node --inspect=9222 main.js",
        "prodbuild": "cross-env NODE_ENV=production npx webpack"
      },
  • 相关阅读:
    git基本报错处理
    上传本地文件到gitee
    Pycharm Process finished with exit code -1073741819 (0xC0000005)
    linux ubuntu 安装后的配置
    Anaconda 和 jupyter notebook入门
    LaTeX公式小结--持续更新中
    markdown基本语法
    Python数据类型的整理
    linux磁盘分区与挂载
    第一章linux系统概述
  • 原文地址:https://www.cnblogs.com/chun321/p/11996410.html
Copyright © 2011-2022 走看看