您当前的位置:首页 > 互联网教程

vuejs在前端开发起到什么作用

发布时间:2025-05-13 02:03:51    发布人:远客网络

vuejs在前端开发起到什么作用

一、vuejs在前端开发起到什么作用

jQuery的诸多局限性导致前端工程师的发展受到了很多的限制,只能做一些表面性的工作,并不能实现前后端分离开发。

而近期出现的Vue,它给前端带来了无限的可能和改变。

改变一:真正意义上的前端工程师

之前开发都是前端做静态页面,把页面给到后台程序员改成jsp、php、asp等等...一顿乱改,一顿塞变量,做完以后页面样式乱七八糟,最后你再调整css。说白了你会html,css就行了,基本没什么门槛,可以这么说。

有了Vue和Node的前端工程化以后,前端工程师能做的事情越来越多,后台人员只需要抛过来一个Api,剩下的就可以都交给前端了。

改变二:服务端渲染VS客户端渲染

传统的jsp、php或是模板渲染也好,都是服务端渲染,就是客户端一个请求,服务器直接把整个页面返回给你,简单粗暴。(Spring Boot是通过模板引擎,由服务端完成的渲染工作)

但是vue开发是前后端分离开发,通过api进行交互,客户端请求服务器返回json数据,由客户端进行渲染。

不仅减轻了服务器的压力速度更快而且渲染更加优雅,代码更容易维护。

jQuery是通过DOM来控制数据,不仅笨重而且渲染数据特别麻烦,而 Vue是通过数据来控制状态,通过控制数据来控制渲染,变量可以直接写在标签中,渲染更加优雅。

因为前端代码和后台代码都是分开的,所以项目更容易维护,开发效率更高。

改变四:项目工程化,结合npm直接安装第三方库

Vue让前端项目更加工程化,同时也规范了前端工程师的代码,而node和npm的加入才是vue能蓬勃发展的重要原因。

Node为Vue提供了本地server和模块化开发的思路,npm更能安装Vue项目需要的模块,配合Vue使用,比如Moment.js Element ui vuex等等,这些第三方库让Vue有了无限的可能。

敲黑板(补充下):传统开发jQuery是命令式编程,现代框架开发是函数式编程。现代框架开发,可以使用Webpack(当然使用jQuery也可以使用Webpack),可以使用人家提供的现成的脚手架,比方说create-react-app,vue-cli。极大提高了开发的效率,并且可以使用最新的ES6、ES7语法进行开发,在编码体验上,就提高了一个档次。

知其然,知其所以然,没有最好的框架,只有最合适的框架!

二、Vue在前端开发中需要注意什么

这次给大家带来Vue在前端开发中需要注意什么,Vue在前端开发的注意事项有哪些,下面就是实战案例,一起来看一下。

组件名应该始终是多个单词的,根组件 App除外。

当在组件中使用 data属性的时候(除了 new Vue外的任何地方),它的值必须是返回一个对象的函数。

//在一个 Vue的根实例上直接使用对象是可以的,

在你提交的代码中,prop的定义应该尽量详细,至少需要指定其类型。

//这样做只有开发原型系统时可以接受

props: ['status']4.为v-for设置键值

在组件上_总是_必须用 key配合 v-for,以便维护内部组件及其子树的状态。甚至在元素上维护可预测的行为,比如动画中的对象固化(object constancy),也是一种好的做法。

<li v-for="todo in todos">

</ul>5.避免 v-if和 v-for用在一起

永远不要把 v-if和 v-for同时用在同一个元素上。

一般我们在两种常见的情况下会倾向于这样做:

为了过滤一个列表中的项目(比如 v-for="user in users" v-if="user.isActive")。在这种情形下,请将 users替换为一个计算属性(比如 activeUsers),让其返回过滤后的列表。

为了避免渲染本应该被隐藏的列表(比如 v-for="user in users" v-if="shouldShowUsers")。这种情形下,请将 v-if移动至容器元素上(比如 ul, ol)。

<ul v-if="shouldShowUsers">

</ul>6.为组件样式设置作用域

对于应用来说,顶级 App组件和布局组件中的样式可以是全局的,但是其它所有组件都应该是有作用域的。

这条规则只和单文件组件有关。你不一定要使用 scoped特性。设置作用域也可以通过 CSS Modules,那是一个基于 class的类似 BEM的策略,当然你也可以使用其它的库或约定。

不管怎样,对于组件库,我们应该更倾向于选用基于 class的策略而不是 scoped特性。

这让覆写内部样式更容易:使用了常人可理解的 class名称且没有太高的选择器优先级,而且不太会导致冲突。

<button class="c-Button c-Button--close">X</button>

<button class="btn btn-close">X</button>

<button class="button button-close">X</button>

<!--使用 `scoped`特性-->

</style>二、强烈推荐(增强可读性)1.组件文件

只要有能够拼接文件的构建系统,就把每个组件单独分成文件。

当你需要编辑一个组件或查阅一个组件的用法时,可以更快速的找到它。

ue.component('TodoList',{

Vue.component('TodoItem',{

单文件组件的文件名应该要么始终是单词大写开头(PascalCase)

|- mycomponent.vue3.基础组件名

应用特定样式和约定的基础组件(也就是展示类的、无逻辑的或无状态的组件)应该全部以一个特定的前缀开头,比如 Base、App或 V。

只应该拥有单个活跃实例的组件应该以 The前缀命名,以示其唯一性。

这不意味着组件只可用于一个单页面,而是每个页面只使用一次。这些组件永远不接受任何 prop,因为它们是为你的应用定制的,而不是它们在你的应用中的上下文。如果你发现有必要添加 prop,那就表明这实际上是一个可复用的组件,只是目前在每个页面里只使用一次。

|- MySidebar.vue5.紧密耦合的组件名

和父组件紧密耦合的子组件应该以父组件名作为前缀命名。

如果一个组件只在某个父组件的场景下有意义,这层关系应该体现在其名字上。因为编辑器通常会按字母顺序组织文件,所以这样做可以把相关联的文件排在一起。

|- SearchSidebarNavigation.vue反例:

|- NavigationForSearchSidebar.vue6.组件名中的单词顺序

组件名应该以高级别的(通常是一般化描述的)单词开头,以描述性的修饰词结尾。

|- SettingsCheckboxLaunchOnStartup.vue反例:

|- LaunchOnStartupCheckbox.vue

|- TermsCheckbox.vue7.模板中的组件名大小写

<!--在单文件组件和字符串模板中-->

<!--在单文件组件和字符串模板中-->

<!--在单文件组件和字符串模板中-->

<myComponent/>8.完整单词的组件名

组件名应该倾向于完整单词而不是缩写。

|- StudentDashboardSettings.vue

|- UserProfileOptions.vue反例:

|- UProfOpts.vue9.多个特性的元素

多个特性的元素应该分多行撰写,每个特性一行。

src=""

<img src="" alt="Vue Logo">

<MyComponent foo="a" bar="b" baz="c"/>10.模板中简单的表达式

组件模板应该只包含简单的表达式,复杂的表达式则应该重构为计算属性或方法。

复杂表达式会让你的模板变得不那么声明式。我们应该尽量描述应该出现的是什么,而非如何计算那个值。而且计算属性和方法使得代码可以重用。

//复杂表达式已经移入一个计算属性

normalizedFullName: function(){

return this.fullName.split('').map(function(word){

return word[0].toUpperCase()+ word.slice(1)

fullName.split('').map(function(word){

return word[0].toUpperCase()+ word.slice(1)

return this.manufactureCost/(1- this.profitMargin)

return this.basePrice*(this.discountPercent|| 0)

return this.basePrice- this.discount

var basePrice= this.manufactureCost/(1- this.profitMargin)

basePrice*(this.discountPercent|| 0)

非空 HTML特性值应该始终带引号(单引号或双引号,选你 JS里不用的那个)。

在 HTML中不带空格的特性值是可以没有引号的,但这样做常常导致带空格的特征值被回避,导致其可读性变差。

<AppSidebar:style="{ width: sidebarWidth+'px'}">反例:

<AppSidebar:style={width:sidebarWidth+'px'}>13.指令缩写

都用指令缩写(用:表示 v-bind:和用@表示 v-on:)

:placeholder="newTodoInstructions"

>三、推荐1.单文件组件的顶级元素的顺序

单文件组件应该总是让<script>、<template>和<style>标签的顺序保持一致。且<style>要放在最后,因为另外两个标签至少要有一个。

<template>...</template>

<script>/*...*/</script>

<style>/*...*/</style>四、谨慎使用(有潜在危险的模式)1.没有在 v-if/v-if-else/v-else中使用 key

如果一组 v-if+ v-else的元素类型相同,最好使用 key(比如两个<p>元素)。

</p>2. scoped中的元素选择器

元素选择器应该避免在 scoped中出现。

在 scoped样式中,类选择器比元素选择器更好,因为大量使用元素选择器是很慢的。

<button class="btn btn-close">X</button>

<button>X</button>

</style>3.隐性的父子组件通信

应该优先通过 prop和事件进行父子组件之间的通信,而不是 this.$parent或改变 prop。

Vue.component('TodoItem',{

@input="$emit('input',$event.target.value)"

Vue.component('TodoItem',{

vm.$parent.todos= vm.$parent.todos.filter(function(todo){

<button@click="removeTodo">

应该优先通过 Vuex管理全局状态,而不是通过 this.$root或一个全局事件总线。

state.list= state.list.filter(todo=> todo.id!== todoId)

三、vue是什么 vue特点 vue和其他前端框架区别

Vue.js(读音/vju?/,类似于 view)是一套基于javascript的用于构建用户界面的渐进式框架。与其他重量级框架不同的是,Vue采用自底向上增量开发的设计。Vue的核心库只关注视图层,它不仅易于上手,还便于与第三方库或既有项目整合。另一方面,当与单文件组件和 Vue生态系统支持的库结合使用时,Vue也完全能够为复杂的单页应用程序提供驱动。

简洁、轻量、组件化、快速、数据驱动、模块友好

都支持指令:内置指令和自定义指令。

都支持过滤器:内置过滤器和自定义过滤器。

1>AngularJS的学习成本高,比如增加了Dependency Injection(依赖注入)特性,而Vue.js本身提供的API都比较简单、直观。

2>在性能上,AngularJS依赖对数据做脏检查,所以Watcher越多越慢。

Vue.js使用基于依赖追踪的观察并且使用异步队列更新。所有的数据都是独立触发的。

对于庞大的应用来说,这个优化差异还是比较明显的。

手机渲染速度:angular1 300ms* vue 200ms* react 100ms

React采用特殊的JSX语法,Vue.js在组件开发中也推崇编写.vue特殊文件格式,对文件内容都有一些约定,两者都需要编译后使用。

中心思想相同:一切都是组件,组件实例之间可以嵌套。

都提供合理的钩子函数,可以让开发者定制化地去处理需求。

都不内置列数AJAX,Route等功能到核心包,而是以插件的方式加载。

在组件开发中都支持mixins的特性。

React依赖Virtual DOM,而Vue.js使用的是DOM模板。React采用的Virtual DOM会对渲染出来的结果做脏检查。

Vue.js在模板中提供了指令,过滤器等,可以非常方便,快捷地操作DOM。

简单地说,就是需要对 DOM进行很多自定义操作的项目小项目;理论上 Vue配合类似Flux的架构也可以胜任超大规模多人协作的复杂项目。