Vue.js项目模板如何大家图文分享

本文主要为大家带来一篇vue.js项目模板搭建图文教程。给大家做个参考,希望能帮助到大家。

前言

从今年(2017年)年初起,我们团队开始引入「Vue.js」开发移动端的产品。作为团队的领头人,我的首要任务就是设计 整体的架构 。一个良好的架构必定是具备丰富的开发经验后才能搭建出来的。虽然我有多年的前端开发经验,但就「Vue.js」来说,仍然是个新手。所幸「Vue.js」有一个配套工具「Vue-CLI」,它提供了一些比较成熟的项目模板,很大程度上降低了上手的难度。然而,很多具体的问题还是要自己思考和解决的。

项目划分

我们公司的H5产品大部分是嵌套在手机客户端里面的页面。每个项目的功能都比较独立,而且规模不大。这样一来,既可以让这些小项目各自为政,也可以把它们集中放到一个大项目中管理。各自的优缺点如下:

立即学习“前端免费学习笔记(深入)”;

Vue.js项目模板如何大家图文分享

项目模板考虑到我们团队刚开始使用「Vue.js」,需要逐步摸索出合适的架构。如果做成一个大项目,一旦架构要调整,很可能会伤筋动骨。所以最终的选择是 划分成多个小项目 。

虽然划分成多个小项目了,但是这些小项目也要保持一致的架构和公共代码。说白了,就是要根据业务情况搭建自己的项目模板,所有具体的项目都在这个模板的基础上开发。下面就介绍一下我们团队的项目模板的搭建过程。

初始化

项目模板本身也是一个项目,所以也通过「Vue-CLI」来初始化(项目名为「webapp-public」):

vue init webpack webapp-public

登录后复制

这里选用的是「webpack」模板,因为功能比较齐全。初始化的过程中要注意:

安装「Vue-Router」以支持单页应用;

安装「ESLint」以统一编码规范。

SASS

安装「SASS」的支持比较简单,先通过命令行安装相关依赖:

npm install node-sass --save-devnpm install sass-loader --save-dev

登录后复制

装好后,只要指定style标签的「lang」属性为「scss」,就可以用该语言来编写样式代码了:


登录后复制

REM布局

如今移动端的页面为了适应不同尺寸的手机屏幕,大多都在样式代码中使用rem作为尺寸单位。然而,设计师给的设计稿还是以px为单位的。这就需要把px转换为rem,这个转换可以在脑子里面转,也可以通过工具去转,比如「PostCSS」的插件「 postcss-px2rem 」。

初始化项目的时候,「PostCSS」就已经装上了,所以直接安装「postcss-px2rem」即可:

npm install postcss-px2rem --save-dev

登录后复制

装好后还要修改项目根目录下的「.postcssrc.js」,增加「postcss-px2rem」的配置:

"plugins": {  "autoprefixer": {},  "postcss-px2rem": { "remUnit": 100 }}

登录后复制

「px值/remUnit」即为转换出来的rem值,可以根据自身需要修改「remUnit」的值。

然而,有些特殊的px值是不需要转换成rem值的,这时候可以通过特殊注释禁止「postcss-px2rem」去处理这个值。例如:

/* 不同dpr下的细线 */.g-dpr-1 .g-border-1px {  border-width: 1px !important; /*no*/ } .g-dpr-2 .g-border-1px {  border-width: 0.5px !important; /*no*/ }

登录后复制

Vuex

在单页应用开发中,负责管理状态的「Vuex」也是必备的。安装也非常简单:

npm install vuex --save

登录后复制

然而,真正使用的时候,在一些 低版本系统的浏览器 中,可能会出现这样的异常:

Error: [vuex] vuex requires a Promise polyfill in this browser.

这是因为浏览器不支持「Promise」,这时候就需要一个「polyfill」。我们可以直接用「babel-polyfill」:

npm install babel-polyfill --save

登录后复制

「babel-polyfill」会在 全局作用域 添加ES6新增的对象和方法,项目中的其他代码并不需要显式地引入(import或者require)它,这就意味着「Webpack」不会把它识别为项目的依赖。所以还要修改「/build/webpack.base.conf.js」,在打包入口处增加「babel-polyfill」:

entry: {  app: ['babel-polyfill', './src/main.js']}

登录后复制

另外要提一下的是,使用「Vue-CLI」初始化项目的时候默认安装了「 babel-plugin-transform-runtime 」,而它的作用跟「babel-polyfill」是重复的,所以可以移除前者。修改根目录下的「.babelrc」,移除这一行:

"plugins": ["transform-runtime"]

登录后复制

然后删除依赖即可:

npm uninstall babel-plugin-transform-runtime --save-dev

登录后复制

访问路径

每个小项目真正在服务器(不管是测试、预发布还是生产环境的服务器)上运行的时候,是通过一级子目录去区分的。

Vue.js项目模板如何大家图文分享

这就意味着,项目中的所有路径都要加上一层目录(比如原访问路径为「http://localhost:8080/home」,现在就得改成「http://localhost:8080/project-a/home」)。千万别以为这是很简单的事情,实际上要改的地方是很多的。

首先要改的是「Vue-Router」的 基路径 配置:

new Router({  base: '/project-a/', // 基路径 mode: 'history',  routes: [ { path: '/', component: Home }]});

登录后复制

设置基路径后,跟路由相关的所有路径都是相对基路径,而不是根目录。

然后是开发服务器的 资源发布路径 (/config/index.js):

dev: { assetsPublicPath: '/project-a/' }

登录后复制

对应地还要修改「/build/dev-server.js」的两处地方,不然访问的时候就会404:

require('connect-history-api-fallback')({  // 默认为"/index.html",因为资源发布路径改了,所以这里也要对应上 index: '/project-a/index.html' })// 运行项目后默认打开的页面地址var uri = 'http://localhost:' + port + '/project-a/'

登录后复制

最后还要修改 Webpack热更新的检测路径 。先修改「/build/dev-server.js」:

require('webpack-hot-middleware')(compiler, {  log: false,  path: '/project-a/__webpack_hmr' })

登录后复制

然后修改「/build/dev-client.js」:

require('webpack-hot-middleware/client?path=__webpack_hmr&dynamicPublicPath=true&noInfo=true&reload=true')

登录后复制

顺带一提,上面的这堆参数完全是用源代码调试的结果,官网文档并没有详细说明。

全部改完之后可以发现,跟目录有关的代码有5处,具体项目使用的时候岂不是要改5次?非常麻烦。这种情况下,把这部分逻辑写成一个公共函数去调用是最好的选择。新建文件「 /src/add-dirname.js 」:

const DIR_NAME = '/project-a/';module.exports = function(path) {  return (DIR_NAME + path).replace(//{2,}/g, '/');};

登录后复制

然后把刚才涉及添加一级子目录的代码全部改成调用该函数来实现:

Vue.js项目模板如何大家图文分享

这样一来,如果要修改一级子目录,只需要修改常量「DIR_NAME」的值就可以了。

公共代码

我们的公共代码分为三种:

通用性较强的库 :包括团队成员编写的一些通用库、无法通过npm安装的通用库等,跟业务无关;

业务逻辑库 :跟业务有关,但是跟表现层无关的公共代码;

业务组件库 :表现层的组件。

它们都位于「/src/public」:

Vue.js项目模板如何大家图文分享

在每一种公共代码的文件夹内,具体某一个库或者组件的目录结构如下:

/src/public/components/img-box

img-box.vue

1.1

这里要特别提一下的是 版本号 这一层文件夹。如果对库或者组件的修改会造成以前的调用代码不兼容,就不应该修改原文件,而是新建一个版本号文件夹,把新的代码以及其余的资源文件都放到这个新文件夹中。这样做的好处是,具体的项目要更新公共代码时,直接把项目模板的「/src/public」覆盖过去就行,不用担心不兼容。

构建

「webpack」这个项目模板已经配置好构建的逻辑。通过一个命令就可以执行构建:

npm run build

登录后复制

根据默认配置,代码会被发布到项目根目录下的「dist」文件夹内。然而,这样简单粗暴的发布方式并不能满足实际需求:

资源文件(图片、CSS、JS等)要发布到 CDN服务器 ;

HTML中要通过完整的URL引用资源文件(因为资源文件在CDN的域上);

不用的环境(测试、预发布、生产)使用不同的域访问。

先解决区分环境的问题,我们在构建命令中新增一个参数以表示环境:

npm run build 

登录后复制

然后在根目录下新建一个配置文件「conf.json」(简单起见,只写了两种环境的配置):

Vue.js项目模板如何大家图文分享

文件内容表示的分别是不同环境下的HTML文件发布路径、资源发布路径以及资源访问路径。

接下来就要把这些配置接入到「Webpack」的打包配置中。修改「/config/index.js」,先在开头加上:

var env = process.argv[2]; // 环境参数(从0开始的第二个)var conf = require('../conf');// 找出对应环境的配置conf.indexRoot = conf.indexRoots[env];conf.assetsRoot = conf.assetsRoots[env];conf.assetsPublicPath = conf.assetsPublicPaths[env];

登录后复制

然后修改构建部分的代码:

build: {  index: path.resolve(__dirname, conf.indexRoot + 'index.html'), assetsRoot: path.resolve(__dirname, conf.assetsRoot), assetsPublicPath: conf.assetsPublicPath}

登录后复制

此时运行构建命令,就可以把项目发布到「conf.json」指定的路径中。

小结

至此,项目模板搭建完毕。其实最重要的一点就是 可配置化 ,否则,开发具体项目的人初始化一个项目还要改十几个地方,效率就很低了。

项目模板的使用

项目模板已经搭建好了,但是怎么用呢?有两种常用场景:

初始化新项目 :克隆或拉取项目模板项目,复制该项目的所有文件(除了「.git」文件夹)到新项目的文件夹,修改配置后进行后续开发。

更新公共代码 :克隆或拉取项目模板项目,复制要更新的代码到目标项目的对应路径。

两种场景都离不开「克隆或拉取」、「复制和粘贴」,这种做法一是麻烦,二是逼格太低。所以后来我用Node.js写了一个命令行工具「webapp-cli」来完成这两项工作。

初始化项目的命令为:

webapp init [projectPath]

登录后复制

例如:

webapp init test

登录后复制

更新特定文件的命令为:

webapp update  [projectPath]

登录后复制

例如:

webapp update /src/public/** test

登录后复制

这个工具并没有改变操作方式,只是由人工操作变成程序代劳。

相关推荐:

vue.js项目打包上线的图文讲解

以上就是Vue.js项目模板如何大家图文分享的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2787397.html

(0)
上一篇 2025年3月8日 18:07:08
下一篇 2025年3月8日 18:07:14

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • 原生js和canvas模拟心电图代码分享

    使用原生js+canvas制作的模拟心电图的html页面,因为和项目一起打包放到了github上,所以使用了vue.js的单页模式,实际上你不需要使用任何额外的框架和样式,也可以完成这个demo,现在让我们一起来拆解这个项目吧! 1:在页面…

    编程技术 2025年3月8日
    000
  • JS实现静态页面搜索并高亮显示的代码

    本文主要和大家介绍js实现静态页面搜索并高亮显示功能,涉及javascript事件响应、字符遍历替换及页面元素属性动态变换等相关操作技巧,需要的朋友可以参考下,希望能帮助到大家。 nbsp;html>JS搜索搜索这是主体内容,有很多内…

    2025年3月8日
    200
  • javascript实现全屏滚动功能

    本文主要和大家介绍原生javascript实现的全屏滚动功能,涉及javascript事件响应及页面元素属性动态操作相关实现技巧,需要的朋友可以参考下,希望能帮助到大家, 原理: 1. 计算当前浏览器屏幕高度,每次翻页显示的内容高度即为屏幕…

    编程技术 2025年3月8日
    200
  • JavaScript原生态兼容IE6可调控滚动文字功能

    一、基本目标 如下图,一开始文字能在15px-400px这个区域以每0.05s,5px像素的无缝滚动,当然,改改下面的脚本,你让我从地球滚动到外太空都没问题,只要你告诉我地球的px和外太空的px就行了,然后设置两个按钮,你点击“停止”它就停…

    2025年3月8日
    200
  • angularjs猜数字大小功能实现方法

    本文主要和大家详细介绍angularjs实现猜数字大小功能,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能帮助到大家。  猜一猜,多大值?(1-1000) 我猜是: 验证再玩一次 0″>您猜的数大了 您猜的数小了 您猜对了 …

    编程技术 2025年3月8日
    200
  • js的变量提升和函数提升详解

    本文为大家带来一篇基于js的变量提升和函数提升(详解)。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧,希望能帮助到大家。 一、变量提升 在ES6之前,JavaScript没有块级作用域(一对花括号{}即为一个…

    编程技术 2025年3月8日
    200
  • Angularjs实现分页插件的代码分享

    由于最近的一个项目使用的是angularjs1.0的版本,涉及到分页查询数据的功能,后来自己就用自定义指令实现了该功能。现在单独做了个简易的小demo,主要是为了分享自己写的分页功能。注:本实例调用的是真实接口数据。 首先、小demo的目录…

    2025年3月8日 编程技术
    200
  • JS实现将html转为pdf功能代码分享

    本文主要和大家介绍js实现的将html转为pdf功能,结合完整实例形式分析了基于浏览器端插件jspdf实现的html格式数据转换成pdf具体操作技巧,需要的朋友可以参考下,希望能帮助到大家。 本文实例讲述了JS实现的将html转为pdf功能…

    2025年3月8日
    200
  • JS实现粘贴板复制功能代码分享

    使用剪贴板是一项基本技能。作为码农都应知道, tab , ctrl/cmd + a , ctrl / cmd + c 以及 ctrl / cmd + v 分别是自动聚焦、复制、粘贴的快捷键。 而对普通用户可能就不太容易了。即使用户知道剪贴板…

    编程技术 2025年3月8日
    200
  • JS中offset和匀速动实例分析

    本文主要和大家介绍javascript动画:offset和匀速动画详解(含轮播图的实现),并把实现代码做了分享,有兴趣的朋友参考下,希望能帮助到大家。 offset简介 我们知道,三大家族包括:offset/scroll/client。今天…

    2025年3月8日 编程技术
    200

发表回复

登录后才能评论