vue 2.0 开发实践总结之疑难篇

 

续上一篇文章:vue2.0 开发实践总结之入门篇 ,如果没有看过的可以移步看一下。

本篇文章目录如下:

1.  vue 组件的说明和使用

2.  vuex在实际开发中的使用

3.  开发实践总结

1.  vue 组件的说明和使用

一个组件实质上是一个拥有预定义选项的一个 Vue 实例

在header组件内部允许外部使用,需要导出属性,有2种导出方法

1.  默认导出(不用命名)

1 export default {
2 data () {
3 return {
4 msg: 'header'
5 }
6 }
7 }

以上代码实际上会自动生成一个 new vue

在父组件中导入

1 import Header from './components/header'

2.直接在任何变量或者函数前面加上一个关键字

1 export const sqrt = Math.sqrt;

在父组件中导入

1 import sqrt from './components/header';

引用一个组件  

import Header from './components/header'

在该组件中定义

1  export default{
2 data: function () {}, //data一定要是返回一个函数
3 components: {
4 comHeader: Header //声明组件
5 }
6 }

在template中使用

1 <template>
2 <div class="com-app">
3 <com-header></com-header> //注意,html不区分大小写,所以需要将 comHeader 写成 com-header
4 </div>
5 </template>

一个vue对象通常包括下面几个属性

1 data:      //vue对象的数据
2 methods: //vue对象的方法
3 watch: //对象监听的方法
4 computed: //计算逻辑放到computed中
5 created: //属性已绑定,dom未生成,一般在这里进行ajax处理以及页面初始化处理

2. vuex

通过尤大大这张图,我们很清楚的看到,所有的数据流都是单向的,并且actions只能通过分发mutations来修改 store 实例的状态

像一些全局信息通用,比如 header内容的渲染,是否显示,loading 什么时候显示,什么时候隐藏,以及接口api的固定值,都写在store记录组件的state。
 1 const store = new Vuex.Store({
2 state: {
3 comm: {
4 loading: false, //是否显示loading
5 apiUrl: 'http://www.sherlochao.com:9091/photosharing/', //接口base url
6 imgUrl: 'http://www.sherlochao.com:9091/filebase', //图片base url
7 indexConf: {
8 isFooter: true, // 是否显示底部
9 isSearch: true, // 是否显示搜索
10 isBack: false, // 是否显示返回
11 isShare: false, // 是否显示分享
12 title: '' // 标题
13 }
14 }
15 }
16 })

在mutations中改变state状态

 1 const store = new Vuex.Store({
2 mutations: {
3 //loading的显示
4 isLoading: (state, status) => {
5 state.comm.loading = status
6 },
7 //修改header的信息
8 changeIndexConf: (state, data) => {
9 Object.assign(state.comm.indexConf, data)
10 }
11 })

e.g 在 header.vue 中 控制是否显示

 1 export default {
2 data: function () {
3 return {}
4 },
5 computed: {
6 isShowSearch: function () {
7 return this.$store.state.comm.indexConf.isSearch //获取vuex里面 state 状态值
8 },
9 title: function () {
10 return this.$store.state.comm.indexConf.title
11 },
12 isBack: function () {
13 return this.$store.state.comm.indexConf.isBack
14 }
15 }
16 }

template代码

 1 <template>
2 <div class="header">
3 <div v-show="isShowSearch"></div>
4 <div class="title" v-show="!isShowSearch">
5 <a v-show="isBack" class="back t-icon" @click="goBack"><span
6 class="iconfont icon icon-xiangzuojiantou"></span></a>
7 <p>{{title}}</p>
8 </div>
9 </div>
10 </template>

在其他地方控制 header 是否显示, e.g: 详情页面

 1 export default {
2 created: function () {
3 vm.$store.commit('changeIndexConf', {
4 isFooter: false,
5 isSearch: false,
6 isBack: true,
7 isShare: true,
8 title: '详情页'
9 })
10 }
11 }

3.开发实践总结

1. vue-router

由于整个项目list组件很多地方公用,并且‘我的收藏’,‘搜索结果页面’,‘我的圈子’,仅仅只是从  /search/own 到 /search/star
此时,原来的组件实例会被复用,意味着组件的生命周期钩子不会再被调用
解决方法:  复用组件时,想对路由参数的变化作出响应的话,可以简单地 watch(监测变化)  对象
1 export default {
2 watch: {
3 '$route' (to, from) {
4 // 对路由变化作出响应...
5 }
6 }
7 }

2.判断是否登陆

进入个人信息页面,由于需要判断是否已登陆,此时由 router 进行一个拦截,具体代码如下

1 router.beforeEach(function (to,from,next) {
2 var userMsg = localStorage.getItem('userMsg')
3 if(to.path === '/home'){
4 if(!userMsg){
5 next({ path: '/login' })
6 }
7 }
8 next()
9 })

3.常用api

1. 点击事件获取当前对象

event.target , this为vue 对象
 
2. 和jquery类似获取当前dom对象
1 <input type="submit" disabled="canSubmit" ref="isSubmit" @click="register" value="立即注册" class="button"/>
1 this.$refs.isSubmit.removeAttribute('disabled')   //使用this.$refs 获取当前dom

其他常见的api  可移步   vue2.0官方文档

如果在阅读中有发现任何错误或者有更好的建议,请联系我,谢谢!

vue 2.0-1的更多相关文章

  1. 使用 Vue 2.0 实现服务端渲染的 HackerNews

    Vue 2.0 支持服务端渲染 (SSR),并且是流式的,可以做组件级的缓存,这使得极速渲染成为可能.同时, 和 2.0 也都能够配合 SSR 提供同构路由和客户端 state hydration.v ...

  2. 新手入门指导:Vue 2.0 的建议学习顺序

    起步 1. 扎实的 JavaScript / HTML / CSS 基本功.这是前置条件. 2. 通读官方教程 (guide) 的基础篇.不要用任何构建工具,就只用最简单的 <script> ...

  3. vue 2.0 无法编译ES6语法

    # vue2.0 webpack 无法编译 ES6 语法 之前在使用 vue 1.x 时用 vue-loader@8.0.0 版本可以正常打包vue的代码,包括ES6语法也能正常转为ES5语法,但是当 ...

  4. Vue 2.0初学后个人总结及分享

    摘要:最近在上海找工作,发现Vue前景还不错,于是就打算先学习一下(之前了解过,但是一直没提到日程上)这篇随笔当是为了自己学习之后,做一个小的阶段性总结.希望本文的内容对于刚开始接触vue的朋友们有点 ...

  5. 《vue.js2.0从入门到放弃》学习之路

    原文地址: Vue.js2.0从入门到放弃---入门实例(一):http://blog.csdn.net/u013182762/article/details/53021374 Vue.js2.0从入 ...

  6. Vue 2.0基础语法:系统指令

    本文最初发表于博客园,并在GitHub上持续更新前端的系列文章.欢迎在GitHub上关注我,一起入门和进阶前端. 以下是正文. Vue初体验 新建一个空的项目,引入vue.js文件.写如下代码: &l ...

  7. vue 2.0 路由切换以及组件缓存源代码重点难点分析

    摘要 关于vue 2.0源代码分析,已经有不少文档分析功能代码段比如watcher,history,vnode等,但没有一个是分析重点难点的,没有一个是分析大命题的,比如执行router.push之后 ...

  8. vue-calendar 基于 vue 2.0 开发的轻量,高性能日历组件

    vue-calendar-component 基于 vue 2.0 开发的轻量,高性能日历组件 占用内存小,性能好,样式好看,可扩展性强 原生 js 开发,没引入第三方库 Why Github 上很多 ...

  9. vue cli3.0 结合echarts3.0和地图的使用方法

    echarts 提供了直观,交互丰富,可高度个性化定制的数据可视化图表.而vue更合适操纵数据. 最近一直忙着搬家,就没有更新博客,今天抽出空来写一篇关于vue和echarts的博客.下面是结合地图的 ...

  10. Vue 1.0 和 2.0 执行顺序

    // Vue 生命周期 // Vue 1.0 // 执行步骤:选项/生命周期钩子 // 1 init // 2 created // 3 beforeCompile // 4 compiled // ...

随机推荐

  1. TCP/IP协议握手过程详解

    1,建立连接 在TCP/IP协议中,TCP协议提供可靠的连接服务,采用三次握手建立一个连接,如图1所示. (1)第一次握手:建立连接时,客户端A发送SYN包(SYN=j)到服务器B,并进入SYN_SE ...

  2. 带删除的EditText

    在安卓开发中EditText是比较常用的控件之一,那我们平常看到EditText填写了内容之后右边会出现一个删除的按钮,这样可以方便用户对其中文本清空操作,是非常人性化的,我们可以重写EditText ...

  3. Retrofit源码设计模式解析(下)

    本文将接着<Retrofit源码设计模式解析(上)>,继续分享以下设计模式在Retrofit中的应用: 适配器模式 策略模式 观察者模式 单例模式 原型模式 享元模式 一.适配器模式 在上 ...

  4. Effective Java 59 Avoid unnecessary use of checked exceptions

    The burden is justified if the exceptional condition cannot be prevented by proper use of the API an ...

  5. Python常见数据结构--列表

       列表 Python有6个序列的内置类型,但最常见的是列表和元组. 序列都可以进行的操作包括索引,切片.加.乘.检查成员. 此外,Python已经内置确定序列的长度以及确定最大和最下的元素的方法. ...

  6. 使用Httpclient来替代客户端的jsonp跨域解决方案

    最近接手一个项目,新项目需要调用老项目的接口,但是老项目和新项目不再同一个域名下,所以必须进行跨域调用了,但是老项目又不能进行任何修改,所以jsonp也无法解决了,于是想到了使用了Httpclient ...

  7. 一个初学者对于MVC架构的理解

    我很早之前就开始接触.NET开发,一直都在2.0的框架下,所以对于MVC这种架构,听说过,但没有具体使用过,近期和外部朋友接触时,有了解到他们公司在使用MVC这种架构,所以自己就找来相关资料了解一下M ...

  8. Python2

    安装pycharm专业版,不要汉化 要想写的代码支持linux和2.0版本需要在开头加上注释 #/usr/bin/env python #-*- coding:utf-8 -*- 运算符 结果是值 算 ...

  9. python 小程序练习

    还有一些小bug 基本有 输入用户名密码 认证成功后显示欢迎信息 输出三次后锁定 # -*- coding:utf-8 -*- account_file=('C:\Users\guigu\Deskto ...

  10. POJ 2891 Strange Way to Express Integers【扩展欧几里德】【模线性方程组】

    求解方程组 X%m1=r1 X%m2=r2 .... X%mn=rn 首先看下两个式子的情况 X%m1=r1 X%m2=r2 联立可得 m1*x+m2*y=r2-r1 用ex_gcd求得一个特解x' ...