jd上买了本实践相关的, 看过后,的确是实践项目后的一些分享,有些网上的一些vue2教程没怎么提及

-----------

看完了,有些启发,作了个简单摘要作记录, 对vue2感兴趣的,可以自己网上搜些教程看或买本书看,书是对这的一个梳理。

以下内容为看后,觉得有些帮助的.... 分享如下:

-----------------------------------

第1章
a.render的使用

import Vue from 'vue'
import App from './App.vue'

new Vue({
el:'#app',
render: h => h(App);
})

b.组件模板
<template>
<div id="App"></div>
</template>

<script>
export default{
name:'app'
}
</script>

<style>
</style>

如果希望样式只对当前组件起作用
<style scoped>
@import './assets/todos.less'
</style>

------------------
第2章
a. 用脚手架vue-cli 创建项目
vue init webpack my-project

b. 命名方式约定
src 目录下: 公共组件(components) 、指令(directives)、过滤器(filters)

目录名小写,多于2个的中间用 ‘-’ ,如: login
vue文件名,都用大写驼峰 ,如: LoginForm.vue ItemLists.vue
目前的入口文件用小写 index.vue

c. 组件引用用 别名取代路径引用
在 webpack.base.config.js 中 , 如:
module.exports = {
.....
resolve:{
extension:['','.js'],
alias:{
'bs-select':'bowe_components/bootstarp-select/dist/js/select.js'
}
}
}

-----
其他地方引用
import Selector from 'bs-select'

------------------
第3章
a. 路由,在main.js中加入
import Vue from 'vue'
import VueRouter from 'vue-router'
Vue.use(VueRouter)

b. 众多的路由信息,最好写成一个独立的js文件,如 routes.js
在main.js中修改
import Vue from 'vue'
import App from './App.vue'
import router from './config/routes'

new Vue({
el:'#app',
router
render: h => h(App)
})
----------
routes.js 中如下

import Vue from 'vue'
import VueRouter from 'vue-router'

import Home from './Home.vue'
import Cart from './Cart.vue'
import Me from './Me.vue'

Vue.use(VueRouter)

export default new VueRouter({
mode:'history',
base: __dirname,
routes:[
{path:'/',component:Home},
{path:'/Cart',component:Cart},
{path:'/Me',component:Me}
]
})

c. 页面上不直接使用路由定义, 如: <router-link to="./Cart"></router-link>
路由中要调整更改为
routes:[
{name:'Home',path:'/',component:Home},
{name:'Cart',path:'/Cart',component:Cart},
{name:'Me',path:'/Me',component:Me}
]
------
页面上 <router-link :to="{name:'Home'}" ></router-link> , 这个地方是:to ,这是要传入一个对象而不是字符串

如是动态路由 <router-link :to="{name:'BookDetails',params:{id:1}}"></router-link>

history中router-link的三种模式:
默认调用 push , replace , append
<router-link :to="{name:'Home' replace}"></router-link> , 就没有histiory 记录
<router-link :to="{path:'releatice/path' append}"></router-link> , 如原来是a,现在的单是b, 最终效果是 a/b

------------------
第4章
组件的对应关系
组件注册名称 BookList , 模块标记 book-list

html 中
<div class="section">
<book-list :books="latestUpdated" heading="最新更新">
</book-list>
</div>
<div class="section">
<book-list :books="recommended" heading="编辑推荐">
</book-list>
</div>

在home页 中把他引入
import BookList from './components/BookList.vue'
export default{
data(){
.....
},
components:{BookList},
....
}

------
服务端取数据, 安装 vue-resource
main.js 中加入并使用
import VueResource from 'vue-resource'
Vue.use(VueResource)

还可以在 new Vue 时做点事,如
new Vue({
http:{
root:'/api',
headers:{}
},
....
})

-----
使用了vue-resource 后, 会自动注入一个 $http的对象

原来的jquery ajax ,如:
$.get('/api/home').then(res =>{
self.annoouncement = res.annoouncement
self.slides = res.slides
self.latestUpdated = res.latestUpdated
self.recommended = res.recommended
})

可以优化为

this.$http.get('/api/home').then(res =>{
for prop in res.body{
this[prop] = res.body[prop]
}
},(error) =>{
console.log('获取数据失败')
})

---------
第5章 测试内容相关,先放放
调试 Vue-DevTools

----
第6章
视图和表单处理
推荐了一个模板 UIkit
更多细节需要实践...... more TODO

http拦截器 inteceptor ,基本用法
Vue.http.interceptors.push((request,next)=>{
//请求发送前的处理逻辑

//如加入 弹窗等....
next((response) =>{
//请求发送后的处理逻辑

// 关闭弹窗

return response
})
})

----
第7章
vuex 的使用, 较多
data的替代者 : state 和 getter
action 操作的执行者
只用 mutation 修改状态

服务分离

Vue2实践揭秘 - 书,读后作了一个简单摘要的更多相关文章

  1. Vue2 实践揭秘 错误列表

    京东上的购买地址 作者是土生土长的聪明中国人 https://item.jd.com/12176536.html 64页 const bookID = this.$router.params.id 搞 ...

  2. C语言搬书学习第一记 —— 认识一个简单程序的细节

    #include<stdio.h> /*告诉编译器把stdio.h 中的内容包含在当前程序中,stdio.h是C编译器软件包的标准部分,它提供键盘输入和 屏幕输入的支持studio.h文件 ...

  3. 《Vue2.0 实践揭秘》终于出版啦!

    不知不觉间在园子开博都两年多了,最近一些园友问最近去哪了为何都没有新的文章了.最近确实发生了很多的事,一是忙工作二就是忙着写书.这还得多些园子的小编,自两年前发表的"架构师修炼"系 ...

  4. Code Complete 读后总结和新的扩展阅读计划

    Code Complete 读后总结和新的扩展阅读计划 用了一年时间终于将代码大全读完了,在这里做一个简单的总结,并安排下一阶段的扩展阅读计划. 1.选择代码大全作为我程序员职业入门的第一本书,我认为 ...

  5. 《JavaScript DOM编程艺术》读后总结

    这是我读的第一本关于JS的书,刚开始我为了选择合适的学习JS的书,看了网上许多人的意见,基本上都是推荐先读这本书.书的内容挺简单的,确实很适合初学者看,阅读的过程中不会产生什么障碍.内容虽然简单,但我 ...

  6. 实践GTD三周年后的体会

    从2011年7月开始实践GTD到现在已经3年多了,按照年初设定的目标,应该写点GTD的体会,但提起笔来的时候却发现并没有什么太新的体会,大部分体会都已经在以前的文章中写到了,甚至有些流程已经简化了,看 ...

  7. 新生 & 语不惊人死不休 —— 《无限恐怖》读后有感

    开篇声明,我博客中“小心情”这一系列,全都是日记啊随笔啊什么乱七八糟的.如果一不小心点进来了,不妨直接关掉.我自己曾经写过一段时间的日记,常常翻看,毫无疑问我的文笔是很差的,而且心情也是瞬息万变的.因 ...

  8. [No000062]读书八字诀:怎样将书读得通透?

    从吃透到通透 有种说法,吃透一本书,才算好好读过.然而比吃透境界更高,是通透.吃透仅限于书中内容,通透则是将书中内容与正反上下.古今中外背景知识相互关联. 当你做到读书通透,收获将远远大于手头那一本书 ...

  9. 学习PHP爬虫--《Webbots、Spiders和Screen Scrapers:技术解析与应用实践(原书第2版)》

    <Webbots.Spiders和Screen Scrapers:技术解析与应用实践(原书第2版)> 译者序 前言 第一部分 基础概念和技术 第1章 本书主要内容3 1.1 发现互联网的真 ...

随机推荐

  1. 【CF1157F】Maximum Balanced Circle 求一个相邻元素之间绝对值为小于1的最大环

    题目: https://codeforces.com/contest/1157/problem/F 给出一个序列 , 我们要从序列里面挑出一些数构造成一个相邻元素之间绝对值为小于1的最大环 , 挑选的 ...

  2. (一)Audio子系统之AudioRecord.getMinBufferSize

    在文章<基于Allwinner的Audio子系统分析(Android-5.1)>中已经介绍了Audio的系统架构以及应用层调用的流程,接下来,继续分析AudioRecorder方法中的ge ...

  3. ContentProvider和Cursor以及CursorAdapter三者之间内部链接实现原理 解析

    最近 在学习Android3.0中推出的 Loader 机制,其中CursorLoader 这个加载器说是可以实时监测数据和更新数据,为了一探究竟,就连带的将 ContentProvider和Curs ...

  4. python的面向对象和类

    目录 一.基本知识点 1.面向过程编程 2.面向对象编程 3.注意 二.类的结构 1.类的理解 2.代码形式 3.类和函数的一些区别 4.类中的数据 5.类中的方法(基础) 三.类的实例化 四.类的继 ...

  5. HTML5 五大特性

    一.正则表达式: 相信大家都会非常喜欢这个特性,无须服务器端的检测,使用浏览器的本地功能就可以帮助你判断电子邮件的格式,URL,或者是电话格式,防止用户输入错误的信息,通过使用HTML5的patter ...

  6. 14.Promise对象

    1.Promise的含义 Promise 是异步编程的一种解决方案,比传统的解决方案——回调函数和事件——更合理和更强大.它由社区最早提出和实现,ES6将其写进了语言标准,统一了用法,原生提供了Pro ...

  7. C#(winform)设置窗口置顶

    只要设置窗体的TopMost属性即可: registerForm.TopMost = true;

  8. 开源代码SlidingMenu的使用

    1. 将SlidingMenu导入Android studio3.0 2. 编写代码 left_menu.xml <?xml version="1.0" encoding=& ...

  9. 详解 Webpack+Babel+React 开发环境的搭建

    1.认识Webpack 构建应用前我们先来了解一下Webpack, Webpack是一个模块打包工具,能够把各种文件(例如:ReactJS.Babel.Coffeescript.Less/Sass等) ...

  10. [学习线路] 零基础学习hadoop到上手工作线路指导(初级篇)

    about云课程最新课程Cloudera课程   零基础学习hadoop,没有想象的那么困难,也没有想象的那么容易.在刚接触云计算,曾经想过培训,但是培训机构的选择就让我很纠结.所以索性就自己学习了. ...