8.1. 前置知识学习

  • npm 学习

    • 官方文档
    • 推荐资料
    • 需要了解的知识点
      • package.json

        文件相关配置选项

      • npm 本地安装、全局安装、本地开发安装等区别及相关命令

      • npm script脚步的基本编写能力

有时间专门写一个这样的专题,如果需要可以邮件我。malun666@126.com

  • webpack基础学习

    • 官方文档
    • Webpack了解的知识点:
      • webpack的基本配置
      • 了解webpack常用的loader: less-loader、sass-loader、 vue-loader、style-loader、css-loader、eslint-loader、babel-loader等
      • 熟悉Webpack的webpack-dev-server的基本配置和使用,会配置热更新
  • es6语法学习

    • 阮一峰老师的大作《ECMAScript 6 入门》
    • 需要学习的知识点
      • es6的模块机制
      • 各种最新语法糖,简写、geter、setter、箭头函数
      • 类、继承的心机制 ...
  • nodejs基础知识

    • 知识点学习:

      • 文件操作
      • http服务
      • express
  • 组件化开发思想

8.2. Vue脚手架工具:vue-cli构建实战项目

其实如果编写Vue的前端项目,直接使用vue的官方vue-cli构建工具最好用,一个命令就可以直接生成项目的结构和目录。 而且官方需要依赖的包也可以自动配置好,只需要npm instal一下,然后就可以开发测试了。

8.2.1. vue-cli安装

  1. # 安装vue-cli。 安装之前首先确保你已经安装好了nodejs 而且打开命令行
  2. $ npm install -g vue-cli
  3. # 校验一下是否安装成功
  4. $ vue -V
  5. #=> 2.5.1 我当前的版本是这个,你的可能比这个新

8.2.2. 使用vue-cli初始化项目

通过以下命令的方式可以创建一个项目文件夹,并初始化对应的文件。

  1. $ vue init <template-name> <project-name>

其中template-name可以取以下值,每个值对应不同的项目构建的模板。

  • webpack--全功能的Webpack + vueify,包括热加载,静态检测,单元测试
  • webpack-simple--一个简易的Webpack + vueify,以便于快速开始。
  • browserify--全功能的Browserify + vueify,包括热加载,静态检测,单元测试
  • browserify-simple--一个简易的Browserify + vueify,以便于快速开始。

安装和开发控制台的命令:

  1. # 如果已经安装,请省略
  2. $ npm install -g vue-cli
  3. # 初始化一个webpack全功能包的vue项目,请您把my-project换成你自己的项目名。
  4. $ vue init webpack my-project
  5. # 用命令行进入当前项目目录
  6. $ cd my-project
  7. # npm安装所有的依赖的包
  8. $ npm install
  9. # 运行测试的首页
  10. $ npm run dev

8.2.3. 综合实例开发记录

  1. 通过vue-cli构建工具初始化项目目录

安装过程,控制台会问你项目名称是什么?项目描述?项目作者,是否使用eslint校验,是否使用单元测试等....

我的安装过程如下请参考:

  1. $ vue init webpack ttl # => 安装webpack模板的项目 ttl(项目名可以随便取)
  2. A newer version of vue-cli is available.
  3. latest: 2.6.0
  4. installed: 2.5.1
  5. This will install Vue 2.x version of template.
  6. For Vue 1.x use: vue init webpack#1.0 ttl
  7. ? Project name mydemovue # => 项目名称
  8. ? Project description A Vue.js project # => 项目描述
  9. ? Author malun <malun666@126.com> # => 作者
  10. ? Vue build standalone # => 是否支持单文件组件
  11. ? Use ESLint to lint your code? Yes # => 是否支持ESLint代码校验
  12. ? Pick an ESLint preset Standard # => 校验的标准是什么?
  13. ? Setup unit tests with Karma + Mocha? Yes # => 是否使用单元测试
  14. ? Setup e2e tests with Nightwatch? Yes # => 是否使用e2e测试
  15. vue-cli · Generated "ttl".
  16. To get started:
  17. cd ttl
  18. npm install
  19. npm run dev
  20. Documentation can be found at https://vuejs-templates.github.io/webpack

通过上面一系列的命令后,我们就会创建一个webpack配置好的项目包。目录结构如下:

  1. ttl
  2. |--.babelrc #=> babel的配置文件,主要用于转换es6等最新的js语法。
  3. |--.editorconfig #=> 编辑器配置
  4. |--.eslintignore #=> eslint的忽略校验的配置文件
  5. |--.eslintrc.js #=> eslint的配置校验js是否规范的配置文件
  6. |--.gitignore #=> 设置git忽略的管理的文件
  7. |--README.md #=> readme说明文件
  8. |--build/ #=> 自动构建存放的文件地方
  9. |--config/ #=> 当前开发、测试等配置的文件,需要懂点nodejs了啊。
  10. |--index.html #=> 项目的主入口的模板
  11. |--package.json #=> npm的配置文件
  12. |--src/ #=> 源码目录
  13. |--static/ #=> 静态资源存放的目录
  14. |--test/ #=> 测试相关目录
  1. 初始化依赖包
  1. $ cd ttl #=> 进入上面创建好的项目目录
  2. $ npm install #=> 安装所有的依赖包。 安装过程可能非常长,网络也可能有问题,请耐心等待。
  3. # 安装完成后,可以直接运行测试,如果自动打开浏览器,并跳转到http://localhost:8080/ 说明一切都ok了。
  4. $ npm run dev

npm 安装的时候经常网会断开,国内的网(哎,说多了都是泪)你懂的。最好能科学上网,或者是用淘宝的npm的镜像

  1. 安装vue-router组件
  1. $ npm i -S vue-router
  1. 到项目的

    /src/components/

    目录下创建三个组件文件。

分别是:

  • 首页组件

    1. <template>
    2. <div class="home">
    3. <h3>{{ msg }}</h3>
    4. </div>
    5. </template>
    6. <script>
    7. export default {
    8. name: 'home', // 组件可以有自己的名字。
    9. data () { // 组件的data必须是函数
    10. return {
    11. msg: '这里是Home视图'
    12. }
    13. }
    14. }
    15. </script>
    16. <style scoped>
    17. h3 {
    18. background-color: #82c;
    19. }
    20. </style>
  • 用户首页组件

    1. <template>
    2. <div>
    3. <h3>{{ msg }}</h3>
    4. </div>
    5. </template>
    6. <script>
    7. export default { // es6的模块导出定义语法,此模块导出默认的对象
    8. name: 'user', // 组件可以有自己的名字。
    9. data () { // 组件的data必须是函数
    10. return {
    11. msg: '这里是User视图'
    12. }
    13. }
    14. }
    15. </script>
    16. <style scoped>
    17. h3 {
    18. background-color: red;
    19. }
    20. </style>
  • 产品组件

    1. <template>
    2. <div class="product">
    3. <h3>{{ msg }}</h3>
    4. </div>
    5. </template>
    6. <script>
    7. export default {
    8. name: 'product', // 组件可以有自己的名字。
    9. data () { // 组件的data必须是函数
    10. return {
    11. msg: '这里是Home视图'
    12. }
    13. }
    14. }
    15. </script>
    16. <style scoped>
    17. h3 {
    18. background-color: green;
    19. }
    20. </style>

项目的目录结构为:

  1. ttl
  2. |-- src
  3. |--|-- Hello.vue
  4. |--|-- Home.vue
  5. |--|-- Product.vue
  6. |--|-- User.vue
  1. 创建router对象及配置路由

src目录下创建approuter.js文件。 然后添加如下代码:

  1. import VueRouter from 'vue-router' // 导入路由模块
  2. import Home from './components/Home.vue' // 导入Home组件
  3. import User from './components/User.vue'
  4. import Product from './components/Product.vue'
  5. export default new VueRouter({ // 定义路由规则对象
  6. routes: [
  7. {path: '/home', component: Home},
  8. {path: '/user/:id', component: User},
  9. {path: '/product/:id', component: Product}
  10. ]
  11. })
  1. 修改main.js文件 找到src/目录下的main.js文件, 共修改4处,添加路由引用、添加路由规则对象导入、启用路由、将路由键入到Vue中。
    修改此文件为:
  1. // The Vue build version to load with the `import` command
  2. // (runtime-only or standalone) has been set in webpack.base.conf with an alias.
  3. import Vue from 'vue'
  4. import App from './App'
  5. import VueRouter from 'vue-router' // +++1、导入路由组件
  6. import router from './approuter' // +++2、导入我们自己写的路由配置文件
  7. // +++ 3、使用路由组件
  8. Vue.use(VueRouter)
  9. /* eslint-disable no-new */
  10. new Vue({
  11. el: '#app',
  12. template: '<App/>',
  13. components: { App },
  14. router: router // +++4、添加路由对象
  15. })
  1. 在app.vue中添加路由导航

最终代码如下:

  1. <template>
  2. <div id="app">
  3. <nav class="top-menu">
  4. <ul >
  5. <li v-for="item in menuList">
  6. <router-link :to="item.url">{{ item.name }}</router-link>
  7. </li>
  8. </ul>
  9. </nav>
  10. <hr>
  11. <div>
  12. <router-view></router-view>
  13. </div>
  14. </div>
  15. </template>
  16. <script>
  17. export default {
  18. name: 'app',
  19. data: function () {
  20. return {
  21. menuList: [
  22. { name: '首页', url: '/home' },
  23. { name: '用户', url: '/user/19' },
  24. { name: '产品', url: '/product/20' }
  25. ]
  26. }
  27. }
  28. }
  29. </script>
  30. <style>
  31. #app {
  32. }
  33. .top-menu ul, .top-menu li {
  34. list-style: none;
  35. }
  36. .top-menu {
  37. overflow: hidden;
  38. }
  39. .top-menu li {
  40. float: left;
  41. width: 100px;
  42. }
  43. </style>

刷新一下浏览器,你将会看到最终的运行结果。


联系老马

对应视频地址:https://chuanke.baidu.com/s5508922.html
老马qq: 515154084
老马微信:请扫码

 
微信:Flydragon_malun 或者18911865673

08Vue.js快速入门-Vue综合实战项目的更多相关文章

  1. 09Vue.js快速入门-Vue入门之Vuex实战

    9.1. 引言 Vue组件化做的确实非常彻底,它独有的vue单文件组件也是做的非常有特色.组件化的同时带来的是:组件之间的数据共享和通信的难题. 尤其Vue组件设计的就是,父组件通过子组件的prop进 ...

  2. 06Vue.js快速入门-Vue组件化开发

    组件其实就是一个拥有样式.动画.js逻辑.HTML结构的综合块.前端组件化确实让大的前端团队更高效的开发前端项目.而作为前端比较流行的框架之一,Vue的组件和也做的非常彻底,而且有自己的特色.尤其是她 ...

  3. 07Vue.js快速入门-Vue路由详解

    对于前端来说,其实浏览器配合超级连接就很好的实现了路由功能.但是对于单页面应用来说,浏览器和超级连接的跳转方式已经不能适用, 所以各大框架纷纷给出了单页面应用的解决路由跳转的方案. Vue框架的兼容性 ...

  4. Vue.js+vue-element搭建属于自己的后台管理模板:Vue.js快速入门(二)

    Vue.js+vue-element搭建属于自己的后台管理模板:Vue.js快速入门(二) 前言 上篇文章对Vue.js有了初步理解,接下来我们把Vue.js基础语法快速的过一遍,先混个脸熟留个印象就 ...

  5. Node.js快速入门

    Node.js是什么? Node.js是建立在谷歌Chrome的JavaScript引擎(V8引擎)的Web应用程序框架. 它的最新版本是:v0.12.7(在编写本教程时的版本).Node.js在官方 ...

  6. JS快速入门(二)

    目录 JS快速入门(二) 结构图 BOM window对象 open() window子对象 location对象 history对象(了解) navigator 对象 screen对象 BOM 定时 ...

  7. MySQL数据库快速入门与应用实战(阶段一)

    MySQL数据库快速入门与应用实战(阶段一) 作者 刘畅 时间 2020-09-02 实验环境说明: 系统:centos7.5 主机名 ip 配置 slavenode3 172.16.1.123 4核 ...

  8. Vue.js—快速入门

    Vue.js是什么 Vue.js 是一套构建用户界面的渐进式框架.与其他重量级框架不同的是,Vue 采用自底向上增量开发的设计.Vue 的核心库只关注视图层,它不仅易于上手,还便于与第三方库或既有项目 ...

  9. Vue.js—快速入门及实现用户信息的增删

    Vue.js是什么 Vue.js 是一套构建用户界面的渐进式框架.与其他重量级框架不同的是,Vue 采用自底向上增量开发的设计.Vue 的核心库只关注视图层,它不仅易于上手,还便于与第三方库或既有项目 ...

随机推荐

  1. Yslow---一款很实用的web性能测试插件

    YSlow可以对网站的页面进行分析,并告诉你为了提高网站性能,如何基于某些规则而进行优化. YSlow可以分析任何网站,并为每一个规则产生一个整体报告,如果页面可以进行优化,则YSlow会列出具体的修 ...

  2. 如何使用SetTimer

    1.SetTimer定义在那里? SetTimer表示的是定义个定时器.根据定义指定的窗口,在指定的窗口(CWnd)中实现OnTimer事件,这样,就可以相应事件了. SetTimer有两个函数.一个 ...

  3. POJ 2976 Dropping tests (0/1分数规划)

    Dropping tests Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 4654   Accepted: 1587 De ...

  4. 【SqlServer】Sql Server 支持的数据类型

    在计算机中数据有两种特征:类型和长度.所谓数据类型就是以数据的表现方式和存储方式来划分的数据的种类.    在SQL Server 中每个变量.参数.表达式等都有数据类型.系统提供的数据类型分为几大类 ...

  5. JetBrains C++ IDE CLion配置与评测

    等了大半年的JetBrains C++ IDE千呼万唤始出来!上次我猜2014年肯定发布,今天经@wet2_cn同学的提醒,我去官博一看,嘿!有了!赶紧安装试了一把,感觉这是迄今为止用过最好的Cpp ...

  6. Git 撤消操作(分布式版本控制系统)

    1.覆盖提交 有时候我们提交完了才发现漏掉了几个文件没有添加,或者提交信息写错了.此时,可以运行带有 --amend 选项的提交命令尝试重新提交. $ git commit --amend 或 # g ...

  7. android 4.x环境搭建

    一.Android搭建开发环境 (一).工具准备 原文地址:http://www.open-open.com/lib/view/open1386252535564.html 1.下载JDK JDK即J ...

  8. iOS UILabel设置居上对齐,居中对齐,居下对齐

    在iOS中默认的UILabel中的文字在竖直方向上仅仅能居中对齐,博主參考国外站点.从UILabel继承了一个新类,实现了居上对齐,居中对齐,居下对齐.详细例如以下: // //  myUILabel ...

  9. STM8在IAR中Option Byte配置

    转http://www.stmcu.org/module/forum/thread-607140-1-1.html 近期帮客户调试STM8的程序使用到OptionByte配置,在网上查询几乎都是介绍如 ...

  10. KMP算法理解

    1.KMP算法解决问题:对BF(Brute Force)算法优化,避免对主串进行回溯匹配(匹配不成功主串指针向后移1位,子串指针重置开始位置,两串继续匹配),效率底. 2.KMP算法原则/目的:主串不 ...