Vue2实践揭秘 - 书,读后作了一个简单摘要

时间:2021-12-15 09:16:07

Vue2实践揭秘 - 书,读后作了一个简单摘要

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&period;0 实践揭秘》终于出版啦!

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

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

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

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

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

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

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

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

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

  8. &lbrack;No000062&rsqb;读书八字诀:怎样将书读得通透?

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

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

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

随机推荐

  1. Mysql 5&period;7&period;12 配置

    打算用express+mysql写一个博客.本来在公司电脑已经配置好了的,但是为了方便在家里也能修改,所以在自己的电脑里也安装好环境. 公司电脑是win7系统32位的,安装的是5.5的mysql,用的 ...

  2. &lbrack;ZZ&rsqb;Sign Up for the First-Ever Appium Roadshow on August 20th in New York City

    http://sauceio.com/index.php/2014/07/appium-roadshow-nyc/?utm_source=feedly&utm_reader=feedly&am ...

  3. 《C语言入门很简单》欢乐槽点

    p24 在C语言中,有三种基本的数据类型供选择,它们有着不同的精度和广度,可以根据自己的需要选择合适的.这三种数据类型分别是整型.浮点型.字符型,它们可谓是C语言数据的三大变形金刚. p237 评:自 ...

  4. JS参数传值

    1.JS获取URL参数值 //js获取url参数值 function request(paras) { var url = location.href; , url.length).split(&qu ...

  5. codeforces Ilya and Matrix

    http://codeforces.com/contest/313/problem/C #include <cstdio> #include <cstring> #includ ...

  6. &star; &lbrack;洛谷P2633&rsqb; Count on a tree 「树上主席树」

    题目类型:主席树+\(LCA\) 传送门:>Here< 题意:给出一棵树.每个节点有点权.问某一条路径上排名第\(K\)小的点权是多少 解题思路 类似区间第\(K\)小,但放在了树上. 考 ...

  7. Spring Boot默认的JSON解析框架设置

    方案一:启动类继承WebMvcConfigurerAdapter,覆盖方法configureMessageConverters ... @SpringBootApplication public cl ...

  8. addEventListener和attachEvent区别

    addEventListener()是标准的绑定事件监听函数的方法,是W3C所支持的,Chrome.FireFox.Opera.Safari.IE9.0及其以上版本都支持该函数:但是,IE8.0及其以 ...

  9. Linux中的In命令

    ln是linux中一个非常重要命令.它的功能是为某一个文件在另外一个位置建立一个同步的链接,这个命令最常用的参数是-s,具体用法是: ln -s  源文件 目标文件    -s 是 symbolic的 ...

  10. UNITY 模型与动画优化选项

    1,RIG: Optimze Game Objects,[默认是没勾选的] 效果:将骨骼层级从模型中移除,放到动画控制器中,这样性能提高明显.实测中发现原来瞬间加载5个场景角色有点延迟,采用此选项后流 ...