首页技术vue前端,web前端三大主流框架

vue前端,web前端三大主流框架

编程之家2026-07-01659次浏览

今天给各位分享vue前端的知识,其中也会对web前端三大主流框架进行解释,如果能碰巧解决你现在面临的问题,别忘了关注本站,现在开始吧!

vue前端,web前端三大主流框架

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

基于Vue官方风格指南整理

一、强制

1.组件名为多个单词

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

正例:

export default{

vue前端,web前端三大主流框架

name:'TodoItem',

//...

}

反例:

export default{

name:'Todo',

vue前端,web前端三大主流框架

//...

}

2.组件数据

组件的 data必须是一个函数。

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

正例:

// In a.vue file

export default{

data(){

return{

foo:'bar'

}

}

}

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

//因为只存在一个这样的实例。

new Vue({

data:{

foo:'bar'

}

})

反例:

export default{

data:{

foo:'bar'

}

}

3. Prop定义

Prop定义应该尽量详细。

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

正例:

props:{

status: String

}

//更好的做法!

props:{

status:{

type: String,

required: true,

validator: function(value){

return [

'syncing',

'synced',

'version-conflict',

'error'

].indexOf(value)!==-1

}

}

}

反例:

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

props: ['status']

4.为v-for设置键值

总是用 key配合 v-for。

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

正例:

<ul>

<li

v-for="todo in todos"

:key="todo.id"

>

{{ todo.text}}

</li>

</ul>

反例:

<ul>

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

{{ todo.text}}

</li>

</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">

<li

v-for="user in users"

:key="user.id"

>

{{ user.name}}

</li>

</ul>

反例:

<ul>

<li

v-for="user in users"

v-if="shouldShowUsers"

:key="user.id"

>

{{ user.name}}

</li>

</ul>

6.为组件样式设置作用域

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

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

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

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

正例:

<template>

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

</template>

<!--使用 BEM约定-->

<style>

.c-Button{

border: none;

border-radius: 2px;

}

.c-Button--close{

background-color: red;

}

</style>

反例:

<template>

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

</template>

<style>

.btn-close{

background-color: red;

}

</style>

<template>

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

</template>

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

<style scoped>

.button{

border: none;

border-radius: 2px;

}

.button-close{

background-color: red;

}

</style>

二、强烈推荐(增强可读性)

1.组件文件

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

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

正例:

components/

|- TodoList.vue

|- TodoItem.vue

反例:

V

ue.component('TodoList',{

//...

})

Vue.component('TodoItem',{

//...

})

2.单文件组件文件的大小写

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

正例:

components/

|- MyComponent.vue

反例:

components/

|- myComponent.vue

|- mycomponent.vue

3.基础组件名

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

正例:

components/

|- BaseButton.vue

|- BaseTable.vue

|- BaseIcon.vue

反例:

components/

|- MyButton.vue

|- VueTable.vue

|- Icon.vue

4.单例组件名

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

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

正例:

components/

|- TheHeading.vue

|- TheSidebar.vue

反例:

components/

|- Heading.vue

|- MySidebar.vue

5.紧密耦合的组件名

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

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

正例:

components/

|- TodoList.vue

|- TodoListItem.vue

|- TodoListItemButton.vue

components/

|- SearchSidebar.vue

|- SearchSidebarNavigation.vue

反例:

components/

|- SearchSidebar.vue

|- NavigationForSearchSidebar.vue

6.组件名中的单词顺序

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

正例:

components/

|- SearchButtonClear.vue

|- SearchButtonRun.vue

|- SearchInputQuery.vue

|- SearchInputExcludeGlob.vue

|- SettingsCheckboxTerms.vue

|- SettingsCheckboxLaunchOnStartup.vue

反例:

components/

|- ClearSearchButton.vue

|- ExcludeFromSearchInput.vue

|- LaunchOnStartupCheckbox.vue

|- RunSearchButton.vue

|- SearchInput.vue

|- TermsCheckbox.vue

7.模板中的组件名大小写

总是 PascalCase的

正例:

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

<MyComponent/>

反例:

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

<mycomponent/>

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

<myComponent/>

8.完整单词的组件名

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

正例:

components/

|- StudentDashboardSettings.vue

|- UserProfileOptions.vue

反例:

components/

|- SdSettings.vue

|- UProfOpts.vue

9.多个特性的元素

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

正例:

<img

src="htorg/images/logo.png"

alt="Vue Logo"

>

<MyComponent

foo="a"

bar="b"

baz="c"

/>

反例:

<img src="h/logo.png" alt="Vue Logo">

<MyComponent foo="a" bar="b" baz="c"/>

10.模板中简单的表达式

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

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

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

vue是什么

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

vue特点

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

vue和其他前端框架区别

1.与AngularJS的区别

相同点:

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

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

都支持双向数据绑定。

都不支持低端浏览器。

不同点:

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

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

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

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

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

2.与React的区别

相同点:

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

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

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

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

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

不同点:

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

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

vue的应用场景

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

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前端和web前端三大主流框架的问题到这里结束啦,希望可以解决您的问题哈!

asp是什么氨基酸 二十种氨基酸缩写textarea默认显示文字(textarea字数限制)