Vue.js 提供了两种加载组件的方法:一种是 Vue 实例中的全局加载,另一种是组件级的加载。两种方法都有各自的优点。
全局加载的组件可以从应用程序中的任何模板(包括子组件)访问。它限制了将全局组件导入子组件的次数。此外,如果你全局加载组件,就不会得到 Vue 注册组件错误“你注册的组件正确吗?”注意,加载全局组件要谨慎。它会使你的应用程序膨胀,即使不使用,它仍然会包含在你的 webpack 构建中。
importVuefrom'vue';
importEditorfrom'./componetns/Editor.vue'
//Where'editor'isthenameofthe component <editor></editor>
Vue.component('editor', Editor);
局部加载组件使你能够隔离组件,并且只在必要时加载它们。当与 Webpack 结合使用时,你可以只在使用组件时延迟加载它们。这使你的应用程序初始文件较小,并减少了初始加载时间。
<template>
<section>
<editor></editor>
</section>
</template>
<script>
importEditorfrom'./Editor'
exportdefault{
name:'dashboard',
components: {
Editor
}
}
</script>
使用 Webpack 的动态导入来延迟加载组件。Vue 支持在渲染时延迟加载组件和代码分割。这些优化让你可以只在需要时加载组件代码,从而减少 HTTP 请求、文件大小,并自动提高性能。这个特性的重要之处在于,它既可以处理全局加载的组件,也可以处理局部加载的组件。
全局加载异步组件:
importVuefrom'vue';
//Where'editor'isthenameofthe component <editor></editor>
//Returnsa promise thatonlygetscalledwhenthe compoentisrenderedandthencached.
Vue.component('editor', () =>import('./componetns/Editor.vue'));
本地加载异步组件:
<template>
<section>
<editor></editor>
</section>
</template>
<script>
exportdefault{
name:'dashboard',
components: {
'Editor':()=>import('./Editor')
}
}
</script>
“当他们将平均页面加载时间减少 850 毫秒时,COOK 将转化率提高了 7%,跳出率降低了 7%,每次会话增加了 10%。”
有很多方法可以为组件创建 props;你可以传递一个表示 prop 名称的字符串数组,也可以传递一个以键作为 prop 名称的对象和一个配置对象。
使用基于对象的方法,你可以为单个 prop 创建一些键配置更改,其中之一就是必需的键。必需的键需要一个 true 或 false 值。当组件被使用时,如果 prop 没有设置,true 就会抛出一个错误,false(默认值)就不必需或者抛出一个错误。在和其他开发人员共享组件以及提醒你自己某个 prop 对该组件至关重要时,这是很好的做法。
<template>
<section>
<editorv-if="isAdmin"></editor>
</section>
</template>
<script>
exportdefault{
name:'Editor',
props: {
enabled: {},
isAdmin: {
required:true
}
}
}
</script>
子组件和父组件之间的通信可以通过使用组件内置的函数 e m i t 来 发 出 自 定 义 事 件 。
emit 函数接受一个事件名称字符串和要发出的可选值。要侦听事件,只需将“@eventName”添加到发出事件的组件并传入事件处理程序。这是一种很好的方法,可以保持真相的单一来源,并使数据从子组件流向父组件。
<template>
<section>
<button@click="onClick">Save</button>
</section>
</template>
<script>
exportconstSAVE_EVENT ='save';
exportdefault{
name:'triggerEvent',
methods: {
onClick() {
this.$emit(SAVE_EVENT);
}
}
}
</script>
<template>
<section>
<pv-show="showSaveMsg">Thanks for Listening for the saved event</p>
<trigger-event@save="onSave"></trigger-event>
</section>
</template>
<script>
exportdefault{
name:'TriggerEvent',
data(){
return{
showSaveMsg:false
}
},
components:{
//You can find Trigger Custom Events in VueJs https://gist.github.com/eabelard/36ebdc8367bfeff75387cc863c810f65
TriggerEvent:()=>import('./TriggerEvent')
},
methods: {
onSave() {
this.showSaveMsg =true;
}
}
}
说起来容易做起来难,但是你如何定义要将组件分解成什么样的逻辑块?分解组件的第一种方法是基于数据变化率。如果数据在组件的某个部分始终在变化,而在其他部分没有变化,那么它可能应该自成组件。
这样做的原因是,如果你的数据 /html 在模板的一个部分中不断变化,那么整个模板都需要检查和更新。但是,如果将相同的 HTML 放入它自己的组件中,并使用 props 传递数据,那么当它的 props 发生更改时,只有那个组件才会更新。
另一种从逻辑上分解组件的方法是重用。如果你的 HTML、图形或功能在整个应用程序中始终如一地使用,比如按钮、复选框、徽标动画、操作调用或文本简单变化的图形,那么它们就是可以隔离到一个可重用的新组件中的很好的候选项。可重用组件具有易于维护的潜在好处,因为你可以更改一个组件,而不必在代码库中查找替换和更改多个地方。
使用对象表示法来配置每个 prop,而不是使用字符串数组来定义 prop。两种非常有用的配置样式是“type”和 validator。
使用类型参数,Vue 将对你的 prop 值进行自动类型检查。例如,如果我们期望一个 Number prop,但收到了一个 String,你会在控制台收到类似这样的警告:
[Vue warn]: Invalid prop: type check failed for prop “count”. Expected Number
对于更复杂的验证,我们可以将函数传递给 validator 属性,该属性以该值作为参数并返回 true 或 false。这非常强大,因为它允许我们针对传递给该特定属性的值编写自定义验证。
<template>
<section:hljs-attr">status]">
<p>You{{status}}the test</p>
</section>
</template>
<script>
exportdefault{
name:"CustomValidation",
props: {
enabled:Boolean,
status: {
default:"fail",
validator:function(value){
return["pass","fail"].includes(value);
}
}
}
};
</script>
<stylescoped>
.custom-validation{
opacity:0.5;
}
.enabled{
opacity:1;
}
.pass{
color: green;
}
.fail{
color: red;
}
</style>
如果组件有许多 props(比如 5、6、7 或更多),那么不断地为每个 prop 设置绑定可能会变得单调乏味。幸运的是,有一种快速的方法可以设置组件上所有属性的绑定,那就是使用 v-bind 绑定对象,而不是单个属性。
使用对象绑定的另一个好处是可以覆盖来自对象的任何绑定。在我们的例子中,如果我们在 person 对象中将 isActive 设置为 false,那么我们就可以对实际的 person 组件执行另一个绑定,并将 isActive 设置为 true,而不覆盖原始组件。
<template>
<divid="app">
<personv-bind="person":isActive="true"/>
</div>
</template>
<script>
importPersonfrom"./components/Person.vue";
exportdefault{
name:"App",
components: { Person },
data() {
return{
person: {
firstName:"Jaxson",
lastName:"Pierre",
dob:"05/22/1996",
isActive:false
}
};
}
};
</script>
在某些情况下,你可能希望修改从某个 prop 传入的值。然而,这样做你会收到一个警告“避免直接改变一个 prop”,因为你的确不该。相反,使用 prop 值作为局部数据属性的默认值。这样做将使你能够看到原始值,而修改局部数据不会改变 prop 值。
这是有代价的。使用此方法,你的局部数据属性不会对 prop 值作出反应,因此来自父组件的任何对 prop 值的更改都不会更新你的局部值。但如果确实需要这些更新,则可以使用 computed 属性来组合值。
<template>
<main>
<section>
<h2>Non reactive</h2>
<p>{{ localFirstName }}</p>
<button@click.prevent="changeLocalFirstName">Update First Name</button>
</section>
<section>
<h2>Reactive List</h2>
<ol>
<liv-for="item in itemsList":key="item">{{ item }}</li>
</ol>
</section>
</main>
</template>
<script>
exportdefault{
name:"FullName",
props: {
firstName: {
type:String,
default:"Mike"
},
title: {
type:String,
default:"Senior"
},
items: {
type:Array,
default() {
return["lemons","oranges"];
}
}
},
computed: {
itemsList() {
return[...this.items, ...this.localItems];
}
},
data() {
return{
localItems: ["mangos","apples"],
localFirstName:this.firstName
};
},
methods: {
changeLocalFirstName() {
this.localFirstName ="Jackson";
}
}
};
</script>
<stylescoped>
</style>
有两种方法可以在 Vue tests utils 中创建和引导组件。一个是 mount,另一个是 shallow mount;两者各有优缺点。
当你希望在组件及其子组件之间进行共生测试时,mount 技术非常有效。它让你可以测试父组件是否正确地与子组件进行预期的交互。相反,正如名称所示,shallow mount 只实例化父组件并在完全隔离的情况下渲染它,而不考虑它的任何子组件。
那么哪种方法更好呢?这取决于你。你选择的策略应该取决于你自己的可衡量目标。试着在完全隔离的情况下单独测试组件,shallow 方法工作得很好。需要处理包含子组件的组件,而且要确保通信,那么就要使用 mount 选项。一个很好的选择是两者都使用。你并不必局限于一个,以混合搭配满足测试需求为准。
Vue CLI 是一个功能强大的命令行界面,它使得开发人员可以快速地利用大量可以加速工作流的特性。
我经常使用的一个特性是运行 vue serve 并将路径传递给 vue 组件。这样做的好处在于,你可以完全独立地开发组件,同时还可以热重载和遍历组件,直到它的核心功能都完成了为止。不需要临时将新组件导入要开发的页面。
vue serve ./components/views/GoldenRule
在团队中工作时,你可能希望提取一个特定的组件并与其他组件共享。这就需要 Vue CLI 的下一个特性:将 Vue 组件导出为库的能力。当被调用时,Vue 将自动构建一个单文件组件,将 css 移到一个外部 CSS 文件中(可选的,你也可以内联它),并创建 UMD 和 Common .js 文件,以导入其他 JS 项目。
vue build —-target lib --name goldenRule ./components/views/GoldenRule
英文原文: https://levelup.gitconnected.com/10-things-you-should-know-before-writing-your-next-vuejs-component-4f97964611f4
Vuetify 支持SSR(服务端渲染),SPA(单页应用程序),PWA(渐进式Web应用程序)和标准HTML页面。 Vuetify是一个渐进式的框架,试图推动前端开发发展到一个新的水平。
通过给组件传递参数, 可以让组件变得更加可扩展, 组件内使用props接收参数,slot的使用就像它的名字一样, 在组件内定义一块空间。在组件外, 我们可以往插槽里填入任何元素。slot-scope的作用就是把组件内的数据带出来
函数子组件(FaCC )与高阶组件做的事情很相似, 都是对原来的组件进行了加强,类似装饰者。FaCC,利用了react中children可以是任何元素,包括函数的特性,那么到底是如何进行增强呢?
在现代的三大框架中,其中两个Vue和React框架,组件间传值方式有哪些?组件间的传值是灵活的,可以有多种途径,父子组件同样可以使用EventBus,Vuex或者Redux
自定义指令:以v开头,如:v-mybind。bind的作用是定义一个在绑定时执行一次的初始化动作,观察bind函数,它将指令绑定的DOM作为一个参数,在函数体中,直接操作DOM节点为input赋值。
prop的定义:在没有状态管理机制的时候,prop属性是组件之间主要的通信方式,prop属性其实是一个对象,在这个对象里可以定义一些数据,而这些数据可以通过父组件传递给子组件。 prop属性中可以定义属性的类型,也可以定义属性的初始值。
Web组件由三个独立的技术组成:自定义元素。很简单,这些是完全有效的HTML元素,包含使用一组JavaScript API制作的自定义模板,行为和标记名称(例如,<one-dialog>)。
web组件可以直接或间接的调用其他web资源。一个web组件通过内嵌返回客户端内容的另一个web资源的url来间接调用其他web资源。在执行时,一个web资源通过包含另一个资源的内容或者转发请求到另一个资源直接调用。
在实际开发项目中,有时我们会用到自定义按钮;因为一个项目中,众多的页面,为了统一风格,我们会重复用到很多相同或相似的按钮,这时候,自定义按钮组件就派上了大用场,我们把定义好的按钮组件导出,在全局引用,就可以在其他组件随意使用啦,这样可以大幅度的提高我们的工作效率。
Vue中子组件调用父组件的方法,这里有三种方法提供参考,第一种方法是直接在子组件中通过this.$parent.event来调用父组件的方法,第二种方法是在子组件里用$emit向父组件触发一个事件,父组件监听这个事件就行了。
内容以共享、参考、研究为目的,不存在任何商业目的。其版权属原作者所有,如有侵权或违规,请与小编联系!情况属实本人将予以删除!