一、前言

  • 闲暇时间,看了下前端的基础知识,有幸参与了公司公众号项目前面的一个阶段,学习到了一些前端框架的相关知识
  • 小结了一下 自己练习通过新建一个个文件组织起项目的过程中的一些理解

二、项目入口

  • vue 中

    • 1、首先 webpack 的 entry: 为 app: './src/index.js' ,入口为 js 文件

      • 在 webpack 打包后就会在 对应访问的 html 文件里引用 该 js 文件
      • 入口 js 的作用
        • 初始化的一个全局的 vue 实例,使用实例的 render 方法,挂载 App.vue 组件到当前文件夹下路径下的 index.html 中 (多页面应用中可以是其他文件名,一般跟 js 文件名一致,路径由 webpack 中配置的来控制)
      • 在入口 js 中常做的事
        • 挂载 store
        • 挂载 路由 (VueRouter)
        • 设置 filter
        • 挂载全局变量如网络请求相关 Vue.prototype.$http = axios
        • 引入 reset.css
        • 引入 第三方 UI
        • 设置 rem 相关
    • 2、通过入口 js 来 引用 App.vue 组件
      • App.vue 是最外层的一层
      • App.vue 中常做的事
        • 设置全局的页面滑动、切换动画
        • 设置 <router-view/>
  • react 中

    • 1、首先 webpack 的 entry: 为 app: './src/index.js' ,入口为 js 文件

      • 在 webpack 打包后就会在 对应访问的 html 文件里引用 该 js 文件
      • 入口 js 的作用
        • 使用 ReactDom.render 方法 挂载 组件 到 当前文件夹下 index.html 中
      • 在入口 js 中常做的事
        • 配置 react-redux、redux-thunk 相关
        • 引入 reset.css
        • 引入 第三方 UI
        • 设置 rem 相关
    • 2、通过入口 js 来 引用 app.js 组件
      • app.js 是最外层的一层
      • app.js 中常做的事
        • 设置全局的页面滑动、切换动画 (react-addons-css-transition-group)
        • 设置路由 (react-router-dom )

三、webpack 多页面配置

  • 参考了部分网上的写法

  • 基于 glob 库,得到正确的 js 入口

    // 获得入口 js 文件
    let entries = getEntry('./src/pages/**/*.js', './src/pages/'); // getEntry 方法
    function getEntry(globPath, pathDir) {
    let files = glob.sync(globPath)
    let entries = {},
    entry,
    dirname,
    basename,
    pathname,
    extname
    for (let i = 0; i < files.length; i++) {
    entry = files[i]
    dirname = path.dirname(entry)
    extname = path.extname(entry)
    basename = path.basename(entry, extname)
    pathname = path.normalize(path.join(dirname, basename))
    pathDir = path.normalize(pathDir)
    if (pathname.startsWith(pathDir)) {
    pathname = pathname.substring(pathDir.length)
    }
    entries[pathname] = ['./' + entry]
    }
    return entries
    }
  • 获取对应 html, 配置 html

    // 获取对应 html
    let pages = Object.keys(getEntry('./src/pages/**/*.html', './src/pages/')) // 利用 HtmlWebpackPlugin 配置 html
    pages.forEach(function (pathname) {
    // 配置生成的 html 文件,定义路径等,可根据最终打包的文件要求进行修改
    let page = pathname
    if (pathname.search('/') != -1) {
    page = pathname.split('/').pop()
    } // config 对象
    let config = {
    // html 名字 The file to write the HTML to. Defaults to index.html
    filename: page + '.html', // 模板路径
    // html-withimg-loader! 处理 html,以支持直接在html中使用img的src加载图片
    template: 'html-withimg-loader!' + 'src/pages/' + pathname + '.html', // js 插入位置 When passing true or 'body' all javascript resources will be placed at the bottom of the body element
    inject: true, // html 压缩处理
    minify: {
    // removeComments 移除页面注释,默认为true
    removeComments: true, //collapseWhitespace 移除空格、回车、换行符等符号,默认为true
    collapseWhitespace: false
    }
    // favicon: 'path/to/yourfile.ico'
    }; if (pathname in module.exports.entry) { // chunks 默认会在生成的 html 文件中引用所有的 js 文件,当然你也可以指定引入哪些特定的文件
    // vendors 为第三方库,common 为公共的模块部分,pathname 和 entry 对应 config.chunks = ['common', pathname]; // 给生成的 js 文件一个独特的 hash 值,如 <script type=text/javascript src=bundle.js?22b9692e22e7be37b57e></script> config.hash = false;
    } // 在遍历中配置 (需要生成几个 html 文件,就配置几个 HtmlWebpackPlugin 对象)
    module.exports.plugins.push(new htmlWebpackPlugin(config)); });

小记:vue 及 react 的工程项目入口小结及 webpack 配置多页面应用参考的更多相关文章

  1. vue、react、angular三大框架对比 && 与jQuery的对比

    前端当前最火的三大框架当属vue.react以及angular了. 但是在做项目的时候,我们怎么去选择呢?  这里做一个比较,希望大家可以有一个比较清晰的认识. vue与react vue和react ...

  2. Vue.JS React 精彩文章汇总

    JavaScript深入系列  [干货] JavaScript数组所有API全解密  [干货] 移动端:页面->手淘互动动效的探索 - IT大咖说 - 大咖干货,不再错过 [扫盲] Jonath ...

  3. 谈谈我对前端组件化中“组件”的理解,顺带写个Vue与React的demo

    前言 前端已经过了单兵作战的时代了,现在一个稍微复杂一点的项目都需要几个人协同开发,一个战略级别的APP的话分工会更细,比如携程: 携程app = 机票频道 + 酒店频道 + 旅游频道 + ..... ...

  4. Vue和React对比

    Vue和React对比 Vue也已经升级到2.0版本了,到现在为止(2016/11/19)比较流行的MVVM框架有AngularJS(也有人认为其为MVC).ReactJS和VueJS,这三个框架中, ...

  5. vue和react的介绍

    这几年前端框架发展的不错,出了不少框架,像微软自己的knockoutjs,angular,vue和最近比较火的react等,之前我有写过前两者的相关文章,今天主要说一下后两者. 介绍 是一个用于构建用 ...

  6. vue和react全面对比(详解)

    vue和react对比(详解) 放两张图镇压小妖怪 本文先讲共同之处, 再分析区别 大纲在此: 共同点: a.都使用虚拟dom b.提供了响应式和组件化的视图组件 c.注意力集中保持在核心库,而将其他 ...

  7. Vue vs React: Javascript 框架之战

    https://baijiahao.baidu.com/s?id=1608210396818353443&wfr=spider&for=pc    原文档 正如我们之前提到的,Word ...

  8. vue和react总结

    一.总结一下Vue和React的区别 相同点:   1.都支持服务器端渲染     2.都有Virtual DOM,组件化开发,通过props参数进行父子组件数据的传递,都实现webComponent ...

  9. vue、React Nactive的区别(转载)

    Vue与React的对比 Vue.js与React.js从某些反面来说很相似,通过两个框架的学习,有时候对一些用法会有一点思考,为加深学习的思索,特翻阅了两个文档,从以下各方面进行了对比,加深了对这两 ...

随机推荐

  1. C#类和类的实例

    类 ,顾名思义就是分类.类别的意思.我们要面向对象编程,就需要对不同的事物进行分类.类可以说是.net面向对象的核心. 类:就是具有相同的属性和功能的对象的抽象的集合. 1.类的定义  <访问修 ...

  2. 从CGI到FastCGI到PHP-FPM

    从CGI到FastCGI到PHP-FPM 背景 笔者在学习这几个名词的时候,也是被百度到的相关文章迷惑.涉及到的主要名词包括 1. CGI协议 2. CGI脚本 3. PHP-CGI 4. FastC ...

  3. [开发技巧]·Python极简实现滑动平均滤波(基于Numpy.convolve)

    [开发技巧]·Python极简实现滑动平均滤波(基于Numpy.convolve) ​ 1.滑动平均概念 滑动平均滤波法(又称递推平均滤波法),时把连续取N个采样值看成一个队列 ,队列的长度固定为N ...

  4. OpenStack 负载均衡底层命令创建流程

    1.创建负载均衡器pool-------------不支持高可用的负载均衡器 neutron lb-pool-create --lb-method ROUND_ROBIN --name mypool- ...

  5. bootstrap入门案例

    创建文档基本结构, 包括导入CSS,JS bootstrap初学者模板 添加元件 先添加一个导航栏, 直接粘贴即可使用 https://v4.bootcss.com/docs/4.0/componen ...

  6. MATLAB解决常微分方程

    首先得介绍一下,在matlab中解常微分方程有两种方法,一种是符号解法,另一种是数值解法.在本科阶段的微分数学题,基本上可以通过符号解法解决.   用matlab解决常微分问题的符号解法的关键命令是d ...

  7. NodeJS什么都能做,为什么还要JAVA?

    这张图看起来简单而且很好理解,但没尝试过,会有很多疑问. SPA模式中,后端已供了所需的数据接口,view前端已经可以控制,为什么要多加NodeJS这一层? 多加一层,性能怎么样? 多加一层,前端的工 ...

  8. Linux调优(内存,CPU)

    一.相关概念简介 system call:系统调用 time slice:cpu时间片 O(1):Linux系统进程调度器 page frame:分页 RSS:常驻内存集,无法被页面化的数据 MMU: ...

  9. react native项目在ios上运行测试,亲测

    参考文章:https://segmentfault.com/a/1190000014416132 说明:参考文章中有对AppDelegate.m文件的操作,我的RN版本是0.57.8未设置,也可成功运 ...

  10. JS键盘事件之键控Div

    自上次做的鼠标拖动Div之后,看到fgm.cc的例子,发现用键盘操控Div貌似也是十分有趣,这些DOM操作随着jquery的没落,虽然渐渐少用了,不过有些DOM操作还是必不可少的.现在是虽然数据为王( ...