[code]vue init webpack webapp-public[/code]这里选用的是「webpack」模板,因为功能比较齐全。初始化的过程中要注意: 安装「Vue-Router」以支持单页应用; 安装「ESLint」以统一编码规范。 [b]SASS[/b] 安装「SASS」的支持比较简单,先通过命令行安装相关依赖:
[code]npm install node-sass --save-devnpm install sass-loader --save-dev[/code]装好后,只要指定style标签的「lang」属性为「scss」,就可以用该语言来编写样式代码了:
[code]<style lang="scss" scoped></style><style src="style.scss" lang="scss"></style>[/code][b]REM布局[/b] 如今移动端的页面为了适应不同尺寸的手机屏幕,大多都在样式代码中使用rem作为尺寸单位。然而,设计师给的设计稿还是以px为单位的。这就需要把px转换为rem,这个转换可以在脑子里面转,也可以通过工具去转,比如「PostCSS」的插件「 postcss-px2rem 」。 初始化项目的时候,「PostCSS」就已经装上了,所以直接安装「postcss-px2rem」即可:
npm install postcss-px2rem --save-dev
"plugins": {
"autoprefixer": {},
"postcss-px2rem": { "remUnit": 100 }
}
/* 不同dpr下的细线 */
.g-dpr-1 .g-border-1px {
border-width: 1px !important; /*no*/
}
.g-dpr-2 .g-border-1px {
border-width: 0.5px !important; /*no*/
}
[code]npm install vuex --save[/code]然而,真正使用的时候,在一些 低版本系统的浏览器 中,可能会出现这样的异常: Error: [vuex] vuex requires a Promise polyfill in this browser. 这是因为浏览器不支持「Promise」,这时候就需要一个「polyfill」。我们可以直接用「babel-polyfill」:
[code]npm install babel-polyfill --save[/code]「babel-polyfill」会在 全局作用域 添加ES6新增的对象和方法,项目中的其他代码并不需要显式地引入(import或者require)它,这就意味着「Webpack」不会把它识别为项目的依赖。所以还要修改「/build/webpack.base.conf.js」,在打包入口处增加「babel-polyfill」:
entry: {
app: ['babel-polyfill', './src/main.js']
}
[code]"plugins": ["transform-runtime"][/code]然后删除依赖即可:
[code]npm uninstall babel-plugin-transform-runtime --save-dev[/code][b]访问路径[/b] 每个小项目真正在服务器(不管是测试、预发布还是生产环境的服务器)上运行的时候,是通过一级子目录去区分的。 [img]http://files.jb51.net/file_images/article/201709/20170920081516.jpg[/img] 这就意味着,项目中的所有路径都要加上一层目录(比如原访问路径为「http://localhost:8080/home」,现在就得改成「http://localhost:8080/project-a/home」)。千万别以为这是很简单的事情,实际上要改的地方是很多的。 首先要改的是「Vue-Router」的 基路径 配置:
new Router({
base: '/project-a/', // 基路径
mode: 'history',
routes: [
{ path: '/', component: Home }
]
});
dev: { assetsPublicPath: '/project-a/' }
require('connect-history-api-fallback')({
// 默认为"/index.html",因为资源发布路径改了,所以这里也要对应上
index: '/project-a/index.html'
})
// 运行项目后默认打开的页面地址
var uri = 'http://localhost:' + port + '/project-a/'
require('webpack-hot-middleware')(compiler, {
log: false,
path: '/project-a/__webpack_hmr'
})
require('webpack-hot-middleware/client?path=__webpack_hmr&dynamicPublicPath=true&noInfo=true&reload=true')
const DIR_NAME = '/project-a/';
module.exports = function(path) {
return (DIR_NAME + path).replace(/\/{2,}/g, '/');
};
[code]npm run build[/code]根据默认配置,代码会被发布到项目根目录下的「dist」文件夹内。然而,这样简单粗暴的发布方式并不能满足实际需求: 资源文件(图片、CSS、JS等)要发布到 CDN服务器 ; HTML中要通过完整的URL引用资源文件(因为资源文件在CDN的域上); 不用的环境(测试、预发布、生产)使用不同的域访问。 先解决区分环境的问题,我们在构建命令中新增一个参数以表示环境:
[code]npm run build <test|pre|prod>[/code]然后在根目录下新建一个配置文件「conf.json」(简单起见,只写了两种环境的配置): [img]http://files.jb51.net/file_images/article/201709/20170920081602.jpg[/img] 文件内容表示的分别是不同环境下的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
}
webapp init [projectPath]
webapp init test
webapp update <fileGlobs> [projectPath]
webapp update /src/public/** test
机械节能产品生产企业官网模板...
大气智能家居家具装修装饰类企业通用网站模板...
礼品公司网站模板
宽屏简约大气婚纱摄影影楼模板...
蓝白WAP手机综合医院类整站源码(独立后台)...苏ICP备2024110244号-2 苏公网安备32050702011978号 增值电信业务经营许可证编号:苏B2-20251499 | Copyright 2018 - 2025 源码网商城 (www.ymwmall.com) 版权所有