vue 2.0-1

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官方文档

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

时间: 2024-10-20 05:20:00

vue 2.0-1的相关文章

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

起步 1. 扎实的 JavaScript / HTML / CSS 基本功.这是前置条件. 2. 通读官方教程 (guide) 的基础篇.不要用任何构建工具,就只用最简单的 <script>,把教程里的例子模仿一遍,理解用法.不推荐上来就直接用 vue-cli 构建项目,尤其是如果没有 Node/Webpack 基础. 3. 照着官网上的示例,自己想一些类似的例子,模仿着实现来练手,加深理解. 4. 阅读官方教程进阶篇的前半部分,到『自定义指令 (Custom Directive) 』为止.着

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

Vue 2.0 支持服务端渲染 (SSR),并且是流式的,可以做组件级的缓存,这使得极速渲染成为可能.同时, 和 2.0 也都能够配合 SSR 提供同构路由和客户端 state hydration.vue-hackernews-2.0 是 Vue 作者在GitHub上面放的 Vue 2.0 的一个示例项目,结合 Express.vue-router & vuex 来构建,是很好的学习案例. Features Server Side Rendering Vue + vue-router + vue

Vue v2.0.0-rc.6 发布,轻量级 JavaScript 框架

Vue v2.0.0-rc.6 发布了,Vue.js 是构建 Web 界面的 JavaScript 库,提供数据驱动的组件(基础教程qkxue.net),还有简单灵活的 API,使得 MVVM 更简单(腾云科技ty300.com).本次更新内容如下: Fixed #3610 fix data observation converting prototype keys#3642 fix incorrect duplicate slot warning detection#3657 fix styl

从壹开始前后端分离【 .NET Core2.0 Api + Vue 2.0 + AOP + 分布式】框架之七 || API项目整体搭建 6.2 轻量级ORM

代码已上传Github,文末有地址 书接上文:<从壹开始前后端分离[ .NET Core2.0 Api + Vue 2.0 + AOP + 分布式]框架之六 || API项目整体搭建 6.1 仓储>,我们简单的对整体项目进行搭建,用到了项目中常见的仓储模式+面向接口编程,核心的一共是六层,当然你也可以根据自己的需求进行扩展,比如我在其他的项目中会用到Common层,当然我们这个项目接下来也会有,或者我还会添加Task层,主要是作为定时项目使用,我之前用的是Task Schedule,基本能满足

从壹开始前后端分离【 .NET Core2.0 Api + Vue 3.0 + AOP + 分布式】框架之九 || 依赖注入IoC学习 + AOP界面编程初探

代码已上传Github,文末有地址 说接上文,上回说到了<从壹开始前后端分离[ .NET Core2.0 Api + Vue 2.0 + AOP + 分布式]框架之八 || API项目整体搭建 6.3 异步泛型+依赖注入初探>,后来的标题中,我把仓储两个字给去掉了,因为好像大家对这个模式很有不同的看法,嗯~可能还是我学艺不精,没有说到其中的好处,现在在学DDD领域驱动设计相关资料,有了好的灵感再给大家分享吧. 到目前为止我们的项目已经有了基本的雏形,后端其实已经可以搭建自己的接口列表了,框架已

Vue 2.0开发企业级移动端音乐WebAPP

第1章 课程内容介绍包括课程概述.课程安排.学习前提.讲授方式等方面的介绍,最后演示了整个音乐App的功能,让同学们对课程项目有一个直观的了解.1-1 导学1-2 课前必读(源码获取方式) 第2章 项目准备工作包括项目需求分析.脚手架初始化代码.项目目录介绍及图标字体.公共样式等资源的准备 .2-1 需求分析2-2 Vue-cli脚手架安装2-3 项目目录介绍及图标字体.公共样式等资源准备 第3章 页面骨架开发包括页面入口.header 组件的编写.路由配置及顶导 tab 组件开发.3-1 页面

vue cli3.0用axios调用本地json数据一直报404

最近在基于vue做后台管理系统时,用了vue cli3.0用axios调用本地json数据一直报404,市面上所有的解决办法都没用,快崩溃了,结果最后发现原因是,vue cli3.0 public 文件夹才是静态资源文件,问题解决,记录一下,以后不再踩坑. 最近发现好多人都踩这个坑,索性把我的结构发出来. 参考地址:https://www.love85g.com/?p=1500 原文地址:https://www.cnblogs.com/dapengFly/p/11359456.html

Vue 3.0源码发布,前端程序员:“我真的学不动了!”

那天刷知乎,发现超多人唱衰前端岗,搞的小白和刚入行的新人人心惶惶,不知道自己入行的决定到底是对是错. 前端知识的学习不像上学,只局限在书本上的知识,层出不穷的热点和事件,多到让我们分不清什么是过时和新潮.以前能讲得清 ES6 的人已经很厉害了,可现在 ES8 都出来很久了,真是一刻都不能停止学习. 要是没什么人带领,就算每天都能追上热点,知道潮流的语言,刷再多论坛看再多分享,缺少实操的机会,也是白费功夫. 那么,到底什么样的能力,才是前端开发必备的?你与阿里P6的程序员,差在哪里?前端岗位该如何

vue 2.0 及 vue 3.0 rem配置

vue 2.0 配置 rem 首先先安装postcss-px2rem   (百度可以) https://www.jianshu.com/p/e6476bbc2131 npm install postcss-px2rem 找到文件 build / vue-loader.config.js  添加 const px2rem = require('postcss-px2rem') postcss: function() { return [px2rem({remUnit: 75})]; } 在inde

初识vue 2.0(4):vuex组件通信

0,本来想只用vue就可以做项目了,后来发现不行:一个网页被切分成若干个组件,组件之间是需要数据传递的,因此引入了vuex这个集中式存储.管理的状态管理模式. 1,安装vuex: npm install --save vuex 在main.js中引入: import Vuex from 'vuex' Vue.use(Vuex) 2,创建数据源文件vuex/store.js import Vue from 'vue' import Vuex from 'vuex' Vue.use(Vuex) co