首页 > 前端开发 > 正文

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

2023-10-12 16:55:39 | 我爱编程网

前端开发是很多朋友有关注的类型,那么web开发前端用vue3 Vue在前端开发中需要注意什么,我爱编程网为大家带来了相关文章,希望给大家提供参考。

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

基于Vue3+TS+ElementPlus+Qiankun构建微应用项目

Hello 大家好,这里是Anyin。

最近打算把一个小型项目( 小程序 点餐系统)重构为 微服务 +微应用模式,前端的 技术栈 打算使用Vue3 + TS + ElementPlus + Qiankun 。这里记录下我在构建基础微应用的过程。

重构后的项目相关地址:

•后端: Anyin Cloud [1]

•前端基座: Anyin Cloud Parent[2]

•前端微应用: Anyin Cloud Base[3]

好了,接下来,我们来看看如何基于 Vue3+TS+ElementPlus+Qiankun 构建我们的微应用项目。

另外说下,这里为什么不用 Vite 进行构建,原因是 Vite 目前结合 Qiankun 构建为应用还有点问题(采坑了),所以这里就放弃了。

首先,我们使用 vue-cli 创建一个parent项目:

接着,手动选择我们要添加的组件:

我们选择以下组件进行应用的构建,使用空格键进行多选,然后回车即可:

选择vue3.x版本

相关代码风格、路由模式都是使用默认,css编译我们使用less:

相关编码规范我们使用ESLint + Airbnb Config :

最后,完整的选项如下:

当vue-cli帮我们创建好项目,我们进入项目查看下项目目录,如下:

首先,Qiankun的主应用是需要安装依赖的,微应用无需安装依赖,修改配置即可。这里我们先在主应用安装依赖

接着,进行相关微应用配置。我们新增一个 app.ts ,用于记录所有的微应用的入口:

然后,注册微应用,并导出start方法

导出 start 方法之后,需要在入口处执行该方法

对于整个界面,我们希望整体的布局是这个样子的:

所以,我们在安装 ElementPlus 之后,需要做这样子的布局。

首先,安装 ElementPlus

接着,在 main.ts 引入 ElementPlus 组件,如下:

然后,创建一个布局组件 Layout.vue ,如下:

最后,在App.vue注册该组件

运行起来呈现的效果如下:

微应用的初始化项目同主应用,这里就不详细说明。

微应用无需依赖 Qiankun ,这里我们做一些配置即可。

在 src 目录下新增一个 public-path.js 文件,内容如下:

在 main.ts 引入该文件

新增一个路由 配置文件 ,这里我们创建对应的路由信息,并且兼容独立运行,内容如下:

接着,修改 main.ts 关于实例化的代码,如下:

这里主要是定义个渲染的方法,然后暴露Vue实例,因为等下在微应用的 生命周期 的钩子会使用到。

对于微应用还需要暴露生命周期的钩子方法,这样子主应用才能够识别,在 main.ts 添加如下方法: 我爱编程网

使用 vue 创建项目是没有 vue.config.js 文件的,这里我们手动创建一个,并且配置相关详细,代码如下:

•这里我们导入了 package.json 的 name 字段,因为这里需要和主应用配置的 app.ts 文件的 name 字段一致 • headers 添加跨域配置,因为主应用是通过 fetch 方法来获取微应用的资源的,而微应用是启动在另外一个端口,所以需要添加跨域配置 • output 配置了微应用的打包格式,主应用才能正确识别微应用的一些配置

还记得我们以下这个图不?

我认为 Header 应该是属于主应用,而下面的 Aside 和 Main 都是属于微应用, Aside 块一般都是用于展示菜单,个人认为各个微应用应该各自维护自己的菜单,而不是交由主应用维护。

所以,在微应用,我们还需要处理下左侧的菜单布局。

我们新增一个 Layout.vue 布局文件

至此,Vue3+TS+ElementPlus+Qiankun构建微应用项目的一个基本结构我们已经处理完成,整体运行看下效果:

首页

微应用

好了,基于 Vue3+TS+ElementPlus+Qiankun 的微应用项目基本框架我们已经搭建好了,后续就是慢慢填充一些工具和页面了。

相关源码地址:

•主应用: Anyin Cloud Parent

•微应用: Anyin Cloud Base

[1] Anyin Cloud :
[2] Anyin Cloud Parent:
[3] Anyin Cloud Base:

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

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


这次给大家带来Vue在前端开发中需要注意什么,Vue在前端开发的注意事项有哪些,下面就是实战案例,一起来看一下。
基于Vue官方风格指南整理
一、强制1. 组件名为多个单词
组件名应该始终是多个单词的,根组件 App 除外。
正例:
export default {
name: 'TodoItem',
// ...
}
反例:
export default {
name: 'Todo',
// ...
}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.vue3. 基础组件名
应用特定样式和约定的基础组件 (也就是展示类的、无逻辑的或无状态的组件) 应该全部以一个特定的前缀开头,比如 Base、App 或 V。
正例:
components/
|- BaseButton.vue
|- BaseTable.vue
|- BaseIcon.vue反例:
components/
|- MyButton.vue
|- VueTable.vue
|- Icon.vue4. 单例组件名
只应该拥有单个活跃实例的组件应该以 The 前缀命名,以示其唯一性。
这不意味着组件只可用于一个单页面,而是每个页面只使用一次。这些组件永远不接受任何 prop,因为它们是为你的应用定制的,而不是它们在你的应用中的上下文。如果你发现有必要添加 prop,那就表明这实际上是一个可复用的组件,只是目前在每个页面里只使用一次。
正例:
components/
|- TheHeading.vue
|- TheSidebar.vue反例:
components/
|- Heading.vue
|- MySidebar.vue5. 紧密耦合的组件名
和父组件紧密耦合的子组件应该以父组件名作为前缀命名。
如果一个组件只在某个父组件的场景下有意义,这层关系应该体现在其名字上。因为编辑器通常会按字母顺序组织文件,所以这样做可以把相关联的文件排在一起。
正例:
components/
|- TodoList.vue
|- TodoListItem.vue
|- TodoListItemButton.vue
components/
|- SearchSidebar.vue
|- SearchSidebarNavigation.vue反例:
components/
|- SearchSidebar.vue
|- NavigationForSearchSidebar.vue6. 组件名中的单词顺序
组件名应该以高级别的 (通常是一般化描述的) 单词开头,以描述性的修饰词结尾。
正例:
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.vue7. 模板中的组件名大小写
总是 PascalCase 的
正例:
<!-- 在单文件组件和字符串模板中 -->
<MyComponent/>反例:
<!-- 在单文件组件和字符串模板中 -->
<mycomponent/>
<!-- 在单文件组件和字符串模板中 -->
<myComponent/>8. 完整单词的组件名
组件名应该倾向于完整单词而不是缩写。
正例:
components/
|- StudentDashboardSettings.vue
|- UserProfileOptions.vue反例:
components/
|- SdSettings.vue
|- UProfOpts.vue9. 多个特性的元素
多个特性的元素应该分多行撰写,每个特性一行。
正例:
<img
src="
alt="Vue Logo"
>
<MyComponent
foo="a"
bar="b"
baz="c"
/>反例:
<img src=" alt="Vue Logo">
<MyComponent foo="a" bar="b" baz="c"/>10. 模板中简单的表达式
组件模板应该只包含简单的表达式,复杂的表达式则应该重构为计算属性或方法。
复杂表达式会让你的模板变得不那么声明式。我们应该尽量描述应该出现的是什么,而非如何计算那个值。而且计算属性和方法使得代码可以重用。
正例:
<!-- 在模板中 -->
{{ normalizedFullName }}
// 复杂表达式已经移入一个计算属性
computed: {
normalizedFullName: function () {
return this.fullName.split(' ').map(function (word) {
return word[0].toUpperCase() + word.slice(1)
}).join(' ')
}
}反例:
{{
fullName.split(' ').map(function (word) {
return word[0].toUpperCase() + word.slice(1)
}).join(' ')
}}11. 简单的计算属性
正例:
computed: {
basePrice: function () {
return this.manufactureCost / (1 - this.profitMargin)
},
discount: function () {
return this.basePrice * (this.discountPercent || 0)
},
finalPrice: function () {
return this.basePrice - this.discount
}
}反例:
computed: {
price: function () {
var basePrice = this.manufactureCost / (1 - this.profitMargin)
return (
basePrice -
basePrice * (this.discountPercent || 0)
)
}
}12. 带引号的特性值
非空 HTML 特性值应该始终带引号 (单引号或双引号,选你 JS 里不用的那个)。
在 HTML 中不带空格的特性值是可以没有引号的,但这样做常常导致带空格的特征值被回避,导致其可读性变差。
正例:
<AppSidebar :px' }">反例:
<AppSidebar :px'}>13. 指令缩写
都用指令缩写 (用 : 表示 v-bind: 和用 @ 表示 v-on:)
正例:
<input
@input="onInput"
@focus="onFocus"
>反例:
<input
v-bind:value="newTodoText"
:placeholder="newTodoInstructions"
>三、推荐1. 单文件组件的顶级元素的顺序
单文件组件应该总是让<script>、<template> 和 <style> 标签的顺序保持一致。且 <style> 要放在最后,因为另外两个标签至少要有一个。
正例:
<!-- ComponentA.vue -->
<template>...</template>
<script>/* ... */</script>
<style>/* ... */</style>四、谨慎使用 (有潜在危险的模式)1. 没有在 v-if/v-if-else/v-else 中使用 key
如果一组 v-if + v-else 的元素类型相同,最好使用 key (比如两个 <p> 元素)。
正例:
<p
v-if="error"
key="search-status"
>
错误:{{ error }}
</p>
<p
v-else
key="search-results"
>
{{ results }}
</p>
反例:
<p v-if="error">
错误:{{ error }}
</p>
<p v-else>
{{ results }}
</p>2. scoped 中的元素选择器
元素选择器应该避免在 scoped 中出现。
在 scoped 样式中,类选择器比元素选择器更好,因为大量使用元素选择器是很慢的。
正例:
<template>
<button class="btn btn-close">X</button>
</template>
<style scoped>
.btn-close {
background-color: red;
}
</style>反例:
<template>
<button>X</button>
</template>
<style scoped>
button {
background-color: red;
}
</style>3. 隐性的父子组件通信
应该优先通过 prop 和事件进行父子组件之间的通信,而不是 this.$parent 或改变 prop。
正例:
Vue.component('TodoItem', {
props: {
todo: {
type: Object,
required: true
}
},
template: `
<input
:value="todo.text"
@input="$emit('input', $event.target.value)"
>
`
})反例:
Vue.component('TodoItem', {
props: {
todo: {
type: Object,
required: true
}
},
methods: {
removeTodo () {
var vm = this
vm.$parent.todos = vm.$parent.todos.filter(function (todo) {
return todo.id !== vm.todo.id
})
}
},
template: `
<span>
{{ todo.text }}
<button @click="removeTodo">
X
</button>
</span>
`
})4. 非 Flux 的全局状态管理
应该优先通过 Vuex 管理全局状态,而不是通过 this.$root 或一个全局事件总线。
正例:
// store/modules/todos.js
export default {
state: {
list: []
},
mutations: {
REMOVE_TODO (state, todoId) {
state.list = state.list.filter(todo => todo.id !== todoId)
}
},
actions: {
rem

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

vue3可以用于前后端不分离吗

前后端分离就是后端把数据都封装在一个url地址中,前端只要用ajax去请求就行。不用框架也能实现分离。vueangular是为开发效率而生的。

以后基本上所有的网页都会用前后端分离的架构,但是现在一般的公司还是前后端混合开发,还得看你想去的公司是怎么样的的,大公司的话为了开发效率基本上所有都是前后端分离了,所以并不是说你还要去学vue这些前端的东西。

优点:性能好简单易用前后端分离单页面应用用户体验好缺点:vue是做单页应用的,多页应用虽然也可以做,但是不够灵活。

你都说了是前后端分离,就不需要把vue嵌套php代码里。前后端用纯接口交换数据,找后端同事定义好restful接口,清楚返回的数据结构,接下来前端这块你就可以自己mock数据进行开发了。

以上就是我爱编程网为大家带来的web开发前端用vue3 Vue在前端开发中需要注意什么,希望能帮助到大家,了解更多相关信息,敬请关注我爱编程网。
与“web开发前端用vue3 Vue在前端开发中需要注意什么”相关推荐
vue移动web前端开发 Vue在前端开发中需要注意什么
vue移动web前端开发 Vue在前端开发中需要注意什么

移动前端开发和web前端开发有什么区别?移动前端开发和web前端开发具体区别如下。学习前端开发,推荐千锋教育,一群草根奉献着自己的青春年华,为创造一个有真正社会价值的职业教育机构“千锋教育”而奋力拼搏。web前端开发主要指传统的PC端网页开发,页面主要是运行在PC端浏览器中,移动前端开发出来的页面主要是运行在手机上;直观上会感觉,PC端页面大一些,移动端页面小一些,但是根据开发

2023-09-17 06:25:54
中通web前端开发面试 面试Web前端需要注意什么?会面试哪些问题?
中通web前端开发面试 面试Web前端需要注意什么?会面试哪些问题?

web前端面试必问的几个问题?有那些?web前端面试必问的几个问题?有那些?根据面试官的不同,面试的内容页不一样的。一般的话就是+css布局占一部分,例如各浏览器的相容性,然后就是js的ajax,闭包,冒泡什么的,js会占很大一部分,也有一部分面试官会抛开这些,直接问公司需要的内容,这样的话就是考验你的实际操作了,这类的面试官我很喜欢,就是直接问布局,资料填充之类的,能学到很多东西,

2023-10-10 15:39:53
web前端开发应该注意什么 web前端开发需要掌握哪些技术?
web前端开发应该注意什么 web前端开发需要掌握哪些技术?

Web前端开发的六大误区随着互联网+提出以及移动互联网技术的快速发展,web前端开发越来越重要,在这两年迅速走红,越来越多的开发者加入前端开发队伍。不过目前大学中还没有对前端系统的课程体系,再加上web前端技术的更新迭代,大家对它的认识也各不相同。下面小编给大家介绍web前端开发易出现的六个误区。误区一:网页不全面考虑大部分前端呈现使用DOM,但DOM用得多了会有性能问题。现在很流行

2023-10-04 12:24:07
初学web前端开发 初学Web前端开发要注意什么?
初学web前端开发 初学Web前端开发要注意什么?

如何入门Web前端开发呢?微信小程序的出现无疑给了Web前端一剂强心剂,Web开发程序员的需求也以一种夸张的需求在增长着。眼红于如此火爆的市场的一些求职人员,都纷纷想加入Web前端开发工程师的行列。那么如果你是0基础,那么要如何入门Web前端开发呢?零基础入门有两种方式:第一,通过自己自学进入该行业。第二,通过参加教育培训机构入门。通过自身学习入门你需要通过的是最开始学习时多看看视频

2023-08-29 13:50:08
web前端开发vue3 会vue2学vue3要多久
web前端开发vue3 会vue2学vue3要多久

web前端三大主流框架Web前端三大框架:Vue.js、React.js、Angular.js。1、Vue.jsVuejs的受欢迎度目前是最高的,而开发vuejs的就是一个中国人名字叫尤雨溪。Vue可以通过简洁的API提供高效的数据绑定和灵活的组件系统。同时,尤雨溪选择了开源的方式,方便更多的开发者使用并参与其中。Vue也使用虚拟DOM,因此在项目中的更改不会正式对

2023-10-07 23:27:35
WEB前端开发熟悉vue 前端中的Vue是什么?
WEB前端开发熟悉vue 前端中的Vue是什么?

web前端需要学什么?这里整理了一份web前端学习路线的思维导图,需要掌握和学习的内容如下:第一阶段:专业核心基础阶段目标:1.熟练掌握HTML5、CSS3、Less、Sass、响应书布局、移动端开发。2.熟练运用HTML+CSS特性完成页面布局。4.熟练应用CSS3技术,动画、弹性盒模型设计。5.熟练完成移动端页面的设计。6.熟练运用所学知识仿制

2023-08-30 14:38:56
web前端开发javascript入门 初学Web前端开发要注意什么?
web前端开发javascript入门 初学Web前端开发要注意什么?

WEB前端开发教程WEB前端开发入门攻略1、首先要从基本的HTML语言开始学起。网页的所有内容都是建立在HTML的基础之上,要想学好HTML,不要去使用任何集成工具,而是使用文本编辑器,直接从最简单的HTML可以写起。首先上网下载notepad++文本编辑器,一个好的文本编辑工具能达到事半功倍的效果。2、w3shcool网站提供各种前端开发教程,其教程很适合初学者学习。根据教程的每一步

2023-09-17 05:56:14
现在web前端都是vue模式开发 为什么现在前端开发用vue或react,不用html css
现在web前端都是vue模式开发 为什么现在前端开发用vue或react,不用html css

为什么现在前端开发用vue或react,不用htmlcss我觉得前端更关系的事情应该是界面要好看,开发效率高。在pc端,我觉得现在的网络根本不用去担心多少前端的性能问题。特别是做管理类系统软件,以前用easyui,开发效率非常高,页面也是局部刷新,后来也用bootstrap,因为不是基于js,要局部刷新就得用ajax,确实不好,但我觉得用bootstrapvue,或者新的框架应该往easyu

2023-10-14 22:06:51