Vue+Webpack+css预处理开发单页应用

简介: Vue+Webpack+css预处理开发单页应用

最近 Vue 越来越火了, 知乎上到微博上, 越来越多的人在用它. 之前有学过一点 NG1 , 相比 NG1, VUE 的 API 十分简单.再通过使用 Vue 全家桶, 可以进行更高效的开发. 以下是使用 Vue 全家桶(VueJS + VueRouter + Vuex + Webpack) 开发出来 SPA(单页应用) 的一些过程. 使用的是 豆瓣的公共 API .


安装 Webpack


既然要用全家桶, 那么就需要先使用 Webpack, Webpack 是一个非常方便工具, 能根据配置文件自动地进行 JS 文件的打包.

首先我们需要安装 Node.js. 然后使用 NodeJS 里的 npm (NodeJSPackageManager) 进行包的安装和管理.

安装完毕之后, 打开 cmd , 在项目文件夹内运行 $ npm init , 之后会有一大串要你填的信息, 直接回车到底就行了.

完成之后, 这时项目文件夹中出现了一个 package.json 的文件.

做好了前期的准备工作, 我们现在开始正式安装 webpack , 在 命令行中输入 $ npm i webpack -g , -g 表示 webpack 将会是全局安装, 如果发现安装速度慢或甚至无法安装可以使用 cnpm 或者每次安装时都切换淘宝镜像, 在 -g 后添加 --registry=http://registry.npm.taobao.org , 下同.

等待安装结束, 我们可以开始写 webpack 的配置文件了. 在项目文件夹的根目录创建一个名叫 webpack.config.js 的文件.

然后我们再创建一些文件, 使文件结构像这样:

  • app
  • index.js
  • webpack.config.js
  • package.json
  • index.html

现在, 我们先开始配置 webpack 的入口文件和出口.

代码如下:

module.exports = {
    entry: './app',
    output: {
        path: './build/,
        filename: 'bundle.js'
    }
};

index.html:

<!doctype html>
<html>
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1, user-scalable=no">
</head>
<body>
<script src="./build/bundle.js"></script>
</body>
</html>

接下来,

index.js:    
var h2 = document.createElement('h2');
h2.innerHTMl = 'HELLO VUEJS';document.body.appendChild(h2);

直接在 cmd 中运行 webpack ,就能看到页面显示了一个h2标签,内容是 HELLO VUEJS.


安装 Webpack-dev-server


可以打包之后我们可以让 webpack 运行一个自己的服务器, 并且能在我们文件更新之后, 让其自动刷新

继续使用 cmd , 输入指令 npm i webpack-dev-server --save-dev . --save-dev 会讲安装后的包放在package.json 的devDependencies,一个放在dependencies里面, 产品模式用dependencies,开发模式用devDep.

安装完成之后, 继续往 webpack.config.js 中添加配置.

devServe: {
    historyApiFallback: true,
    hot: true,
    inline: true,
    progress: true
}

再向 package.json"script" 添加配置

"script": {
    "start": "webpack-dev-server --hot --inline"
}

.json 格式的文件里无论键名还是值都必须使用双引号.

写好之后在 cmd 中输入 npm run start 跑出一串字之后, 打开 localhost:8080 , 就能看到结果, 然后我们随意修改一下文本的内容保存一下, 会发现浏览器内的文字自动地刷新了.


如何写 CSS


现在能改动结构了, 但是有了结构就改想想 css 的问题了.

webpack 是把一个文件看作一个模块, 我们需要使用专门的 webpack loader 来处理各式文件.

处理 css 文件时, 我们需要 2个loader, 一个 style-loadercss-loader , 先来安装这两个 loader ,

输入 $ npm i css-loader style-loader --save-dev .

安装完毕后, 我们再来配置 webpack.config.js ,

module: {
    loaders: [
        {
            test: /.css$/, //匹配到所有的css文件            
            loader: 'style!css', //有多种写法, 这是字符串式的写法, style-loader 等loader 可以省去loader 直接写 loader名,            
            loaders: ['style', 'css'], //数组写法, 注意要使用loaders!, loader 的执行顺序是从右到左, 也就是先用css-loader 再使用 style-loader
        }
    ]
}

当然, 我们也可以使用 less sass stylus 等其他的 css 预处理器, 只需要在安装相应的loader, 推荐软件 visual studio...

安装 less-loader , 输入 $ npm i less-loader --save-dev , 等待安装结束后, 检查一下安装的依赖中是否有之前没安装过的, 要继续安装.(这个问题也许是之前我没有安装其他模块的依赖. less-loader 依赖 less ).

这里我们把刚才的 module.loaders 改一下

module: {
    loaders: [
        {
            test: /.less$/, //匹配所有以 .less 结尾的所有文件                     loader: 'style!css!less', //用 less-loader 来处理文件, 要先于 css-loader 处理之前处理 less
            loaders: ['style', 'css', 'less'],
        }
    ]
}

这样,我们也可以使用 less 了.

在 index.js 中以 AMD 方式引入 require('main.less'); . 这样就能愉快书写 less 了.


如何使用 EcmaScript 2015


ES6 已经是2016年之后的趋势了, VueJS 全家桶里的很多例子都是由 ES6 写成的. 是时候使用 EcmaScript 2015 了!

首先我们需要安装 babel-loader 以及 babel :

在命令行内输入

$ npm install --save-dev babel-preset-env

安装babel, 以及

$ npm i --save-dev babel-loader

安装babel-loader

安装之后更改 webpack.config.js 里的module.loaders

...,
{
    test: /.js$/,
    loader: 'babel-loader'
}

babel 要求一个预制值, 可以在

...,
{
    test: /.js$/,
    loader: 'babel-loader',
    query: {
        presets: ['es2015']
    }
}

不过这样写, 在 .vue 文件中的 JS 将无法被处理.

这时 我们应该直接写到

module: ...,babel: {
    presets: ['es2015']
}
[1, 2, 3].forEach( (that) => console.log(that) );

看看转换的结果吧


安装 VueJS, 使用 vue-loader, 单文件组件


搞了这么久, Vue 的 V 字都没开始写.

现在开始安装 Vuejs

$ npm i vue

并且在 index.js 里引入 Vue

import Vue from 'vue';

安装 vue-loader, 这样我们就能够使用 .vue 直接创建单文件组件了.

并且需要在 webpack.config.js 里加入

resolve: {
    alias: {
          'vue$': 'vue/dist/vue.js'
    }
}

引入单文件组件:

import MainView from './components/Mainview.vue';

如何直接用组件渲染到 el: #app 上?

使用

new Vue({
    render (h) {
        h(MainView); //将 MainView 渲染
    }
})
.$mount('#app'); //将渲染到 #app, 将会替换 #app

使用 Vue-router

$ npm install vue-router`

如果本身 应用页面很多的话, 可以将路由文件单独独立出来成一个文件.

首先在 router.js 引入

import Vue from 'vue';
import VueRouter from 'vue-router';
Vue.use(VueRouter);

继续来定义路由:

const router = new VueRouter({
    routes: [
        {
            path: '/',
            component: HeaderVue //当只有一个Vue 没有其他命名路由时使用            components: { 
               //当有其他命名路由时使用, 注意s!
                nameA: HeaderVue,
                nameB: HelloVue,
                default: ContentVue
            }
        }
    ]
});

最后我们将这个参数用 module.export = router; 传递到 index.js .

这里还有一个问题: 如果单独在一个页面里定义路由, 里面的 components 改如何写呢, 相对地址会不好写.

这里 node 提供了个函数 require(['./components/Content.vue'], resolve) 就能直接写了.

component: require(['./components/Content.vue'], resolve);

使用 Vuex

$ npm i vuex

Vuex 是 Vue 的状态管理工具.

import Vuex from 'vuex';
const store = new Vuex.Store({
    state: ..., //状态
    mutations: ..., //同步的改变状态, 请调用 mutation 来改变状态,而不是通过修改state
    actions: ... //异步改变状态
});

Over!

a8bd84093ea0bf6464b9aeed867a536a_640_wx_fmt=png&wxfrom=5&wx_lazy=1&wx_co=1.jpg


目录
相关文章
|
1月前
|
前端开发 JavaScript UED
深入理解与应用 CSS 伪类选择器
【10月更文挑战第23天】通过以上对 CSS 伪类选择器的深入探讨,我们可以更好地理解和应用它们,为网页设计和开发带来更丰富、更灵活的样式效果。同时,要注意在实际应用中根据具体情况合理选择和使用伪类选择器,以达到最佳的设计效果和用户体验。
35 2
|
2月前
|
前端开发 UED
Webpack 中处理 CSS 和图片资源的多 Loader 配置
【10月更文挑战第12天】 处理 CSS 和图片资源是 Webpack 配置中的重要部分。通过合理选择和配置多个 Loader,可以实现对这些资源的精细处理和优化,提升项目的性能和用户体验。在实际应用中,需要不断探索和实践,根据项目的具体情况进行灵活调整和优化,以达到最佳的处理效果。通过对 Webpack 中多 Loader 处理 CSS 和图片资源的深入了解和掌握,你将能够更好地应对各种复杂的资源处理需求,为项目的成功构建和运行提供坚实的基础。
61 1
|
2月前
|
移动开发 JavaScript 前端开发
webpack学习四:使用webpack配置plugin,来使用HtmlWebpackPlugin、uglifyjs-webpack-plugin、webpack-dev-server等插件简化开发
这篇文章主要介绍了如何通过配置Webpack的插件,如HtmlWebpackPlugin、uglifyjs-webpack-plugin和webpack-dev-server,来简化前端开发流程。
52 0
webpack学习四:使用webpack配置plugin,来使用HtmlWebpackPlugin、uglifyjs-webpack-plugin、webpack-dev-server等插件简化开发
|
2月前
|
前端开发 开发者 UED
CSS技术的演变与应用
【10月更文挑战第11天】CSS技术的演变与应用
|
4月前
|
前端开发
酷炫表单,触感未来:HTML与CSS动画的创新应用!
酷炫表单,触感未来:HTML与CSS动画的创新应用!
|
4月前
|
前端开发 Java UED
JSF 面向组件开发究竟藏着何种奥秘?带你探寻可复用 UI 组件设计的神秘之路
【8月更文挑战第31天】在现代软件开发中,高效与可维护性至关重要。JavaServer Faces(JSF)框架通过其面向组件的开发模式,提供了构建复杂用户界面的强大工具,特别适用于设计可复用的 UI 组件。通过合理设计组件的功能与外观,可以显著提高开发效率并降低维护成本。本文以一个具体的 `MessageComponent` 示例展示了如何创建可复用的 JSF 组件,并介绍了如何在 JSF 页面中使用这些组件。结合其他技术如 PrimeFaces 和 Bootstrap,可以进一步丰富组件库,提升用户体验。
56 0
|
4月前
|
前端开发 JavaScript 开发者
【前端革新力】React与CSS-in-JS完美邂逅:从styled-components到emotion,全面解析样式管理新趋势的实战应用与优势剖析!
【8月更文挑战第31天】CSS-in-JS 作为一种新兴的样式管理方式,近年来在前端社区受到广泛关注。它将样式嵌入 JavaScript,实现了样式与逻辑的高度耦合,提升了开发效率并解决了全局样式污染等问题。本文通过具体代码示例,探讨 CSS-in-JS 在 React 开发中的应用,并分享实践心得。首先介绍了 CSS-in-JS 的基本概念,然后详细展示了如何使用 styled-components 和 emotion 这两个流行库创建样式化组件。
174 0
|
4月前
|
JavaScript 前端开发 API
解锁前端开发新境界:Vue.js携手Webpack,打造高效构建流程,你的项目值得拥有!
【8月更文挑战第30天】随着前端技术的发展,模块化与组件化趋势愈发显著。Vue.js 以其简洁的 API 和灵活的组件系统,深受开发者喜爱;Webpack 则凭借强大的模块打包能力成为前端工程化的基石。两者结合,不仅简化了组件编写与引用,还通过模块热替换、代码分割等功能大幅提升开发效率。本文将通过具体示例,展示如何利用 Vue.js 和 Webpack 构建高效、有序的前端开发环境。从安装配置到实际应用,逐步解析这一组合的优势所在。
50 0
|
4月前
|
前端开发 JavaScript Linux
【Azure 应用服务】在Azure App Service for Linux环境中,部署的Django应用,出现加载css、js等静态资源文件失败
【Azure 应用服务】在Azure App Service for Linux环境中,部署的Django应用,出现加载css、js等静态资源文件失败
|
11天前
|
缓存 JavaScript 前端开发
vue学习第四章
欢迎来到我的博客!我是瑞雨溪,一名热爱JavaScript与Vue的大一学生。本文介绍了Vue中计算属性的基本与复杂使用、setter/getter、与methods的对比及与侦听器的总结。如果你觉得有用,请关注我,将持续更新更多优质内容!🎉🎉🎉
27 1
vue学习第四章