收录待用,修改转载已取得腾讯云授权


最近在某个项目中用到了Vue.js,从上手做开发到项目发布,一步步踩了不少坑。本文试图总结过去一个多月使用Vue.js中的一些经验,也算是一点心得体会吧,拿出来与大家分享,欢迎多多交流。

Vue.js简介

Vue.js is a JavaScript framework for building astonishing web applications. Vue.js is a JavaScript library for creating web interfaces. Vue.js is a tool that leverages the use of MVVM architecture.

这是来自Vue.js官网的解释,这里我们不打算再照本宣科的把概念翻译一边了,仅就作者使用Vue.js的心得体会来做出解释。熟悉ReactJS或者Angular的读者可能对此并不陌生。

Vue.js与ReactJS、AngularJS这些框架一样都持有相同的开发理念,通过扩展原生的HTML等结构化标签来作为其模版语言,此外进一步通过语法上的扩展提供了诸如双向数据绑定、交互数据模型等概念,从而使开发者从繁杂的DOM操作中解脱出来,将更多的精力用于关注业务本身的内容。

此外,与React类似的是,均提出了包括虚拟DOM和组件化开发的理念,从而提高了代码的可维护性和性能。Vue.js试图用一种极简的方式来实现以上这些框架带来的优势,因此,相比于React和Angular来说,Vue.js更加轻量、简介和优美。

下面,在进一步探究Vue.js之前,我们先看一下Vue.js的几个核心概念。

组件化

组件化开发是最近两三年比较火的概念。通过使用Vue.js来创建的组件,就像构建万丈高楼的砖块一样,拥有良好的封装性和复用性。每一个组件都拥有其独立的样式和数据域,并且完全与其它组件完全隔离。简单的讲,任何前端的界面都可以通过合理的规划,划分成拥有不同职责的组件。 关于组件化开发的概念我们不再进一步展开,感兴趣的同学可以进一步阅读这篇文章前端工程-基础篇。

Vue.js的插件化

正如你所知,Vue.js的核心部分仅保留了包括数据绑定及组件化开发相关的内容。因此才保证了其极简的机制。此外,对于附加的功能也提供了高效灵活的插件化机制。对于大家耳熟能详的插件包括vue-router、vee-validator、vue-touch等。此外,也提供了允许开发者自己封装组件的机制。从而使你能更有效地抽象某些功能,为团队开发所用。例如,你可以将有关数据计算的逻辑抽象为独立的插件,提供给团队的人使用等。

state和vuex

如果你的项目非常简介,没有复杂的逻辑,那么你完全没必要引入vuex。vuex是用来在应用各个组建之间管理和共享应用state的模块,如果你使用过React那么你应该对Flux不陌生,vuex起到的作用与此类似。

vue-cli

Vue.js也提供了非常高效的命令行工具,通过使用几个简单的命令就能快速构建基于Vue.js的组件和应用,极大的减少了开发者的工作量,将开发者从繁杂的重复性的劳动中解放出来。关于vue-cli,我们不再展开,读者可以阅读vue-cli进一步了解vue-cli的功能。

常用指令

Vue.js提供了包括v-for、v-if、v-show、v-bind、v-model、v-on、v-html等内部指令,这里不再细说每一个指令的用法,读者可以自行参考文档。

需要说明的是v-if和v-show的不同,v-show是通过更改DOM元素的display属性来实现隐藏与否的,而与v-show不同的是,v-if是通过完全移除DOM元素来实现隐藏与否的。因此,如果你的隐藏内容的确需要反复,那么使用v-show,这样性能更好。

v-bind与v-model不同的是,v-model是双向数据绑定,而v-bind是单向绑定的。

v-for使用的时候,最好提供一个key给vue.js。

数据传递

父组件通过props传递数据到子组件 ,子组件通过events来传递数据改变到父组件。对于简单的数据修改,可以通过这种方式实现。但是对于复杂的数据逻辑,建议通过vuex来管理。例如:父组件传递title到子组件:

// 父组件中
<...><child :title="title"></child>
</...>// 子组件
export default {<...>props: ['title'], // 然后就可以通过this.title来使用了<...>
}

子组件传递修改到父组件,通过事件

// 父组件中
<...><child @changeTitle="changeTitle"></child>
</...>
<...>
export default {methods: {changeTitle(text) {this.title = text;}}
}
</...>// 子组件
<template><... :click="onChangeTitle"></...>
</template>
export default {methods: {onChangeTitle (text) {this.$emit('changeTitle', this.id, text)}}
}

对于全局性的state,可以通过vuex来封装。例如用户登录信息,全局都用到的常量信息等。对于vuex的内容比较多,大家可以看这里。vuex api。

生命周期方法

Vue.js提供了一套完整的组件的生命周期钩子方法,你可以在组件的生命周期的各个阶段做该做的事情。其完整的生命周期的方法图示如下:

vue-resource

前端开发不可避免的就是前后端交互,这里非常推荐vue-resource。建议将涉及到前后端交互的所有API放在一个独立的api.js文件当中,方便管理。然后在需要接口的地方导入对应的方法即可。下面是一个示例:

import Vue from 'vue'
import VueResource from 'vue-resource'
Vue.use(VueResource)
const API = {"getYAndMGrade": "//localhost:3000/demo/getYAndMGrade", "createMonthPlan": "//localhost:3000/demo/createMonthPlan"
};
const post = (url,params)=>{return Vue.http.post(url,{params: params}).then(function (res) {return res.data;});
};
// 接口1
export const getYAndMGrade = (user) => {return post(API.getYAndMGrade, {user:user});
};
// 接口2
export const createMonthPlan = (user, month)=> {return post(API.createMonthPlan, {user: user, month: month});
};

vue-router

vue-router是基于vue.js用来解决前端路由的方案。vue-router提供了包括动态路由等功能。这里也给出一个示例:

export default [{name: 'about',path: '/about/',component: require('./pages/about.vue')},{name: 'blog',path: '/blog/:blogId',component: require('./pages/blog.vue')}
]

示例中的blog可以知,我们可以传递id参数并且在组件中过去id。此外,我们可以传递多个参数,如’/blog/:blogID/:postId’等。这里建议不要超过2个,因为传递的越来越多,就不再方便管理了。

组件刷新

作者在使用vue.js的过程中反复遇到过一个问题,就是组件刷新的问题。例如,作者的项目当中有用到菜单,打开不同的菜单对应不同的路由和组件。而如果在当前组件中,再次点击打开当前组件的菜单,则组件并不会刷新。

这就导致一个头疼的问题,因为用户点击菜单本身就是想刷新当前页面,而组件的数据并没有刷新,因此就看不到最新的数据。解决思路就是,在组件路由里增加了一个时间参数,然后在组件当中增加了对这个时间参数的watch。具体是实现如下:

<...><router-link :paht="'/list' + '?_=' + new Date().valueOf()"></router-link>  // 增加当前时间戳_参数
</...>
然后在组件当中watch这个时间参数就可以了:
<...>export default {...watch: {"this.$router._": function() {// refresh data here}}...}
</...>

总结

乱七八糟的写了很多,也算是对这段时间用vue.js的一个回顾。不得不承认,在使用vue.js的过程当中开始逐渐喜欢上了这个优美而简洁的框架。因此也愿意跟更多的人分享使用它的经验。也欢迎大家一起交流。

参考

  • Vue.js官网

  • 《Learning Vue.js》

  • 在组件不变的情况下和url不变的情况下刷新视图

  • 其它参考资料


原文链接:https://www.qcloud.com/community/article/972073

Vue.js 实战总结相关推荐

  1. vue.js实战——购物车练习(包含全选功能)

    vue.js实战第5章 54页的练习1 直接放代码好了,全选的部分搞了好久,代码好像有点啰嗦,好在实现功能了(*^▽^*) HTML: <!DOCTYPE html> <html l ...

  2. js 查错_7年前端开发经验的我,写了本Vue.js实战开发,开源高清PDF下载

    Vue作为目前发展最迅速的前端框架越来越多的受到前端T程师青睐,Vue社区也是Web前端最活跃的社区之一. 更多的公司在转为Vue框架,但针对Vue优秀权威.实战的图书相对欠缺,梁灏著<Vue. ...

  3. vue --- vue.js实战基础篇课后练习

    练习1:在输入框聚焦时,增加对键盘上下键按键的支持,相当于加1和减1 练习2:增加一个控制步伐的prop-step,比如设置为10,点击加号按钮,一次增加10 思路: // 考虑到子模板的复用性,即在 ...

  4. axios vue 动态date_Web前端Vue系列之-Vue.js 实战

    课程简介: 课程目标:通过本课程的学习,让大家掌握Vue.js的进阶知识并在项目中应用. 适用人群:具有一定vue开发基础的开发人员. 课程概述:Vue (读音 /vjuː/,类似于 view) 是一 ...

  5. 3.Vue.js 实战 调查问卷WebApp项目

    问卷调查demo已上传,欢迎大家指正,欢迎大家下载:https://download.csdn.net/download/lzb348110175/11085995 如果您没积分的话,可以私信/评论, ...

  6. 《Vue.js实战》第七章.组件

    7.1 组件作用: 提高代码复用性,使项目易于维护 7.1 组件的使用 7.1.1 组件注册-全局注册 全局注册后,任何vue的实例都可以使用该组件. Vue.component('my-compon ...

  7. Vue.js实战——内置指令(二)

    参考<Vue.js实战>梁灏 Vue内置指令第一部分:Vue.js实战--内置指令(一) 1 方法与事件 1.1 基本用法 直接上代码,这样最实在: <!DOCTYPE html&g ...

  8. Vue.js实战——表单与v-model

    参考<Vue.js实战> 梁灏 1. 基本用法 话不多说,来个入门: <!DOCTYPE html> <html><head><meta char ...

  9. Vue.js实战——内置指令(一)

    参考:<Vue.js实战>梁灏 1. 基本指令 1.1 v-cloak <!DOCTYPE html> <html><head><meta cha ...

  10. [Vue.js] 一篇超级长的笔记,给《Vue.js 实战》划个重点

    本文前言 本笔记建立在书籍<Vue.js实战 / 梁灏编著>的基础上,旨在帮助有 Vue.js 基础的朋友快速回忆 Vue.js 的细碎内容.初学者建议阅读<Vue.js实战> ...

最新文章

  1. 全网最全的Windows下Anaconda2 / Anaconda3里Python语言实现定时发送微信消息给好友或群里(图文详解)...
  2. ​EMC存储产品介绍分析(二):大数据利器Isilon (1)
  3. 在WisOne平台上学习TypeScript
  4. 【Python】内置os.path模块最常用的一些用法
  5. 2019至今TIOBE编程语言排行榜Top 20,Python完胜C++了吗?
  6. 建站用什么cms_我想做独立站,我应该用什么建站工具?
  7. JAVA中日期格式SimpleDateFormat
  8. android 通过代码seekbar控制led闪烁_02【pinpong库控制硬件】之Arduino unoLed闪烁1
  9. 拓端tecdat|R语言逻辑回归(对数几率回归,Logistic)分析研究生录取数据实例
  10. java乐视面试题_乐视面试题 · vagabond1-1983/JavaRock Wiki · GitHub
  11. like语句太慢 sqlserver_SQLSERVER查询速度慢的原因收集以及优化建议
  12. AD09报错解决方法
  13. 图片类word报告生成器
  14. Memcache UDP 反射放大超大规模的DDoS攻击如何防御?
  15. 留言系统php课程设计,PHP课程设计网络留言板
  16. 【游戏设计模式】之一 序言:架构,性能与游戏
  17. Android接电话功能,Android打电话功能
  18. 住院病人主要由护士护理,这不仅需要大量的护士,而且不能随时观察危重病病情,会延误抢救时机以计算机为中心的患者监护系统,写出系统的可行性。并可以系统印出某个指定病人的病情报告。...
  19. c#程序设计 习题7.3
  20. 程序猿如何提高自己的搜索技能

热门文章

  1. Integer Intervals
  2. 最详细的SQL注入语句
  3. IDEA乱码问题(jdk18)
  4. HTML+CSS注册页面案例【Java源代码】
  5. 编译原理实验:Java实现SLR(1)语法分析器
  6. 苹果电脑查看已经连上的WiFi密码(亲测可用)
  7. Tuner及工作原理介绍
  8. MiniGui打开GridView控件
  9. 网页脚本输入这么简单
  10. Python 1~500 求和(循环遍历求和,高斯求和,定义函数求和)