vue2.0开发实践总结之疑难篇

作者:beidan 时间:2024-05-02 16:33:28 

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

本篇文章目录如下:

1.  vue 组件的说明和使用

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

3.  开发实践总结 

1.  vue 组件的说明和使用
一个组件实质上是一个拥有预定义选项的一个 Vue 实例
在header组件内部允许外部使用,需要导出属性,有2种导出方法

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


export default {
data () {
return {
 msg: 'header'
}
}
}

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

在父组件中导入

import Header from './components/header' 

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

export const sqrt = Math.sqrt;

在父组件中导入

import sqrt from './components/header'; 

引用一个组件 

import Header from './components/header'

在该组件中定义


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

在template中使用


<template>
<div class="com-app">

<com-header></com-header> //注意,html不区分大小写,所以需要将 comHeader 写成 com-header
</div>
</template>

 

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




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

2. vuex

 vue2.0开发实践总结之疑难篇

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

像一些全局信息通用,比如 header内容的渲染,是否显示,loading 什么时候显示,什么时候隐藏,以及接口api的固定值,都写在store记录组件的state。


const store = new Vuex.Store({
state: {
comm: {
 loading: false, //是否显示loading
 apiUrl: 'http://www.sherlochao.com:9091/photosharing/', //接口base url
 imgUrl: 'http://www.sherlochao.com:9091/filebase', //图片base url
 indexConf: {
 isFooter: true, // 是否显示底部
 isSearch: true, // 是否显示搜索
 isBack: false, // 是否显示返回
 isShare: false, // 是否显示分享
 title: '' // 标题
 }
}
}
})

在mutations中改变state状态


const store = new Vuex.Store({
mutations: {
//loading的显示
isLoading: (state, status) => {
 state.comm.loading = status
},
//修改header的信息
changeIndexConf: (state, data) => {
 Object.assign(state.comm.indexConf, data)
}
})

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


export default {
data: function () {
 return {}
},
computed: {
 isShowSearch: function () {
 return this.$store.state.comm.indexConf.isSearch //获取vuex里面 state 状态值
 },
 title: function () {
 return this.$store.state.comm.indexConf.title
 },
 isBack: function () {
 return this.$store.state.comm.indexConf.isBack
 }
}
}

template代码


<template>
<div class="header">
<div v-show="isShowSearch"></div>
<div class="title" v-show="!isShowSearch">
 <a v-show="isBack" class="back t-icon" @click="goBack"><span
 class="iconfont icon icon-xiangzuojiantou"></span></a>
 <p>{{title}}</p>
</div>
</div>
</template>

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


export default {
created: function () {
 vm.$store.commit('changeIndexConf', {
 isFooter: false,
 isSearch: false,
 isBack: true,
 isShare: true,
 title: '详情页'
 })
}
}

3.开发实践总结

1. vue-router

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


export default {
watch: {
'$route' (to, from) {
 // 对路由变化作出响应...
}
}
}

2.判断是否登陆

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


router.beforeEach(function (to,from,next) {
var userMsg = localStorage.getItem('userMsg')
if(to.path === '/home'){
if(!userMsg){
 next({ path: '/login' })
}
}
next()
})

3.常用api

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

event.target ,this为vue 对象 

2). 和jquery类似获取当前dom对象
 

<input type="submit" disabled="canSubmit" ref="isSubmit" @click="register" value="立即注册" class="button"/>
 this.$refs.isSubmit.removeAttribute('disabled')   //使用this.$refs 获取当前dom

 

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

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

来源:http://www.cnblogs.com/beidan/archive/2016/12/06/vue.html

标签:vue2.0,开发实践
0
投稿

猜你喜欢

  • python 利用turtle模块画出没有角的方格

    2022-03-09 04:25:04
  • Linux下彻底删除Mysql 8.0服务的方法

    2024-01-14 06:38:04
  • Python下载ts文件视频且合并的操作方法

    2021-11-15 15:40:19
  • vue中英文切换实例代码

    2024-05-29 22:29:37
  • JavaScript 浮动定位提示效果实现代码第1/2页

    2023-07-22 23:26:19
  • python os.system执行cmd指令代码详解

    2022-04-04 07:36:21
  • CSS代码实现下划线样式的输入框效果

    2010-03-16 12:42:00
  • ASP把数字用逗号每3位隔开显示代码

    2008-01-02 13:11:00
  • SQLServer2014故障转移群集的部署的图文教程

    2024-01-28 23:30:06
  • 详解vue-cli本地环境API代理设置和解决跨域

    2024-05-02 16:23:30
  • python自动化测试selenium定位frame及iframe示例

    2023-01-08 16:25:28
  • 详解Vue 多级组件透传新方法provide/inject

    2024-06-05 09:21:03
  • 改善登陆界面的用户体验: 自动聚焦表单

    2009-12-09 16:13:00
  • Python 多线程爬取案例

    2022-11-17 16:02:06
  • linux配置mysql数据库远程连接失败的解决方法

    2024-01-28 06:53:59
  • PHP中动态显示签名和ip原理

    2024-05-11 10:12:33
  • Linux+Nginx+MySQL下配置论坛程序Discuz的基本教程

    2024-05-11 10:46:59
  • python实现猜数字游戏(无重复数字)示例分享

    2023-12-15 19:48:46
  • Web Jmeter–接口测试工具详解

    2022-06-27 04:24:32
  • 解决安装pycharm后不能执行python脚本的问题

    2023-07-25 06:51:04
  • asp之家 网络编程 m.aspxhome.com