博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
vue 2.0 开发实践总结之疑难篇
阅读量:6294 次
发布时间:2019-06-22

本文共 3549 字,大约阅读时间需要 11 分钟。

续上一篇文章: ,如果没有看过的可以移步看一下。 

 

本篇文章目录如下:

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 

 

一个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.title11       },12       isBack: function () {13         return this.$store.state.comm.indexConf.isBack14       }15     }16 }

template代码

1 

在其他地方控制 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 
1 this.$refs.isSubmit.removeAttribute('disabled')   //使用this.$refs 获取当前dom

 

其他常见的api  可移步    

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

原创文章,转发请注明来源!

 

源码github 地址: 

如果有用的话,麻烦star 或者  fork ~ 

 

转载于:https://www.cnblogs.com/beidan/p/vue.html

你可能感兴趣的文章
CuteEditor Html中显示Word格式粘贴的文章[CuteEditor WordToHtml]
查看>>
zabbix 二次开发之调用api接口获取历史数据
查看>>
给自己定的目标
查看>>
LAMP平台部署及应用
查看>>
Supervisor 托管服务
查看>>
分享一下收到的微软CRM云分享计划 邮件
查看>>
DVWA系列之21 存储型XSS分析与利用
查看>>
Hyper-V 2016 系列教程25 配置NFS 存储服务器
查看>>
vCloud Automation Center (vCAC) 6.0 (一)
查看>>
oracle 11g dataguard安装出现的错误
查看>>
Microsoft Dynamics CRM 2013 试用之系统篇 Windows Server 2012 R2安装
查看>>
Skype For Business 2015实战系列6:后端数据库安装CU6补丁
查看>>
web安全之信息刺探防范(上)
查看>>
Oracle CRS的管理与维护
查看>>
开启Sharepoint 2013站点邮箱
查看>>
【VMCloud云平台】SCO(一)规划
查看>>
相对路径和绝对路径错误造成的漏洞
查看>>
元胞自动机:更接近人类思考的智能模型
查看>>
ISCSI网络存储
查看>>
开源跳板机(堡垒机)Jumpserver v0.2.0 使用说明
查看>>