vue学习十二( v-model用于自定义组件、父子组件通信、组件绑定原生事件、具名插槽、插槽作用域、动态组件is和keep-alive)

本文主要是介绍vue学习十二( v-model用于自定义组件、父子组件通信、组件绑定原生事件、具名插槽、插槽作用域、动态组件is和keep-alive),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

      • 自定义组件的 v-model
      • 子组件跟父组件通信
      • 将原生事件绑定到组件
      • 单个插槽
      • 插槽内容
      • 具名插槽
      • 作用域插槽
      • is 特性实现动态组件
      • 动态组件使用 keep-alive

自定义组件的 v-model

一个组件上的 v-model 默认会利用名为 value 的 prop 和名为 input 的事件,但是像单选框、复选框等类型的输入控件可能会将 value 特性用于不同的目的。model 选项可以用来避免这样的冲突

 <div id="lll"><base-checkbox v-model="lovingVue"></base-checkbox><span>{{lovingVue}}</span></div><script>Vue.component('base-checkbox', {model: {prop: 'checked',event: 'change'},props: {checked: Boolean},template: `<inputtype="checkbox"v-bind:checked="checked"v-on:change="$emit('change', $event.target.checked)">`})new Vue({el: "#lll",data: { lovingVue: true }})</script>

效果图:
在这里插入图片描述
在这里插入图片描述

子组件跟父组件通信

 <!-- 但子组件怎么跟父组件通信呢?这个时候 Vue 的自定义事件系统就派得上用场了。 --><!--   使用 $on(eventName) 监听事件使用 $emit(eventName, optionalPayload) 触发事件 --><!-- 父组件可以在使用子组件的地方直接用 v-on 来监听子组件触发的事件。 --><!-- 必须在模板里直接用 v-on绑定事件 -->
 <div id="div1"><p>{{total}}</p><custom v-on:chufa="changeParent"></custom><custom v-on:chufa="changeParent"></custom></div><script type="text/javascript">Vue.component("custom", {template: '<button v-on:click="m_click">{{data}}</button>',data: function () {return { data: 0 }},methods: {m_click: function () {this.data += 1this.$emit("chufa")}}})new Vue({el: "#div1",data: {total: 0},methods: {changeParent: function () {this.total += 1}}})</script>

效果如下:
在这里插入图片描述

将原生事件绑定到组件

你可能有很多次想要在一个组件的根元素上直接监听一个原生事件。这时,你可以使用 v-on 的 .native 修饰符:

   <div id="app"><my-comp @click.native="doThis"></my-comp><div @click="doThis">我是元素</div></div><script>Vue.component('my-comp', {template: '<div>我是组件</div>'});new Vue({el: '#app',methods: {doThis: function () {console.log('click');}}});</script>

单个插槽

<!-- 1、单个插槽 --><div id="exp1"><my-com></my-com></div><script type="text/javascript">//子组件,备用内容在子组件的作用域内编译,并且只有在宿主元素为空时,且没有要插入的内容时才显示备用内容Vue.component('child-com', {template: '<div><h2>我是子组件的标题</h2>' +'<slot>只有在没有要分发的内容时才会显示</slot>' +'</div>'});//父组件Vue.component('my-com', {template: '<div><h1>我是父组件的标题</h1>' +'<child-com>' +'<p>这是一些初始内容</p>' +'<p>这是另外一些初始内容</p>' +'</child-com>' +'</div>'});var exp1 = new Vue({el: '#exp1'})</script>

输出如下:

我是父组件的标题
我是子组件的标题
这是一些初始内容这是另外一些初始内容

插槽内容

到现在,我们知道了什么是插槽:

插槽就是Vue实现的一套内容分发的API,将元素作为承载分发内容的出口

<div id="app"><child-component>哈哈{{a}}</child-component></div><script>Vue.component('child-component', {template: `<div>Hello,World!<slot></slot></div>`})let vm = new Vue({el: '#app',data: {a: "haha",}})</script>

我们现在给组件增加一个插槽
我们在内写的"你好"起作用了!!!

效果如下:

Hello,World! 哈哈haha

具名插槽

<div id="app"><child-component><template slot="girl">漂亮、美丽、购物、逛街</template><template slot="boy">帅气、才实</template><div>我是一类人,我是默认的插槽</div></child-component></div><script>Vue.component('child-component',{template:`<div><h4>这个世界不仅有男人和女人</h4><slot name="girl"></slot><div style="height:1px;background-color:red;"></div><slot name="boy"></slot><div style="height:1px;background-color:red;"></div><slot></slot></div>`})let vm = new Vue({el:'#app',data:{}})</script>

效果如下:
在这里插入图片描述

作用域插槽

先看一个最简单的例子!!

我们给元素上定义一个属性say(随便定义的!),接下来在使用组件child,然后在template元素上添加属性slot-scope!!随便起个名字a

我们把a打印一下发现是 {“say” : “你好”},也就是slot上面的属性和值组成的键值对!!!

这就是作用域插槽

我可以把组件上的属性/值,在组件元素上使用!

  <div id="app"><child><template slot-scope="ab">{{ab}}</template></child></div><script>Vue.component('child', {template: `<div><slot say="你好"></slot></div>`})let vm = new Vue({el: '#app',data: {}})</script>

效果如下:

{ "say": "你好" }

is 特性实现动态组件

我们在一个多标签的界面中使用 is 特性来切换不同的组件
当在这些组件之间切换的时候,你有时会想保持这些组件的状态,以避免反复重渲染导致的性能问题。

<div id="example"><button @click="change">切换页面</button><component :is="currentView"></component></div><script>var home = { template: '<div>我是主页</div>' };var post = { template: '<div>我是提交页</div>' };var archive = { template: '<div>我是存档页</div>' };new Vue({el: '#example',components: {home,post,archive,},data: {index: 0,arr: ['home', 'post', 'archive'],},computed: {currentView() {return this.arr[this.index];}},methods: {change() {this.index = (++this.index) % 3;}}})</script>

动态组件使用 keep-alive

我们之前曾经在一个多标签的界面中使用 is 特性来切换不同的组件:

<component v-bind:is="currentTabComponent"></component>

当在这些组件之间切换的时候,你有时会想保持这些组件的状态,以避免反复重渲染导致的性能问题。例如我们来展开说一说这个多标签界面:
在这里插入图片描述

你会注意到,如果你选择了一篇文章,切换到 Archive 标签,然后再切换回 Posts,是不会继续展示你之前选择的文章的。这是因为你每次切换新标签的时候,Vue 都创建了一个新的 currentTabComponent 实例。

重新创建动态组件的行为通常是非常有用的,但是在这个案例中,我们更希望那些标签的组件实例能够被在它们第一次被创建的时候缓存下来。为了解决这个问题,我们可以用一个 元素将其动态组件包裹起来。

我们来看一个例子

<div id="example3"><button @click="change">切换页面</button><keep-alive><component :is="currentView"></component></keep-alive></div><script>new Vue({el: '#example3',data: {index: 0,arr: [{ template: `<div>我是主页</div>` },{ template: `<div>我是提交页</div>` },{ template: `<div>我是存档页</div>` }],},computed: {currentView() {return this.arr[this.index];}},methods: {change() {let len = this.arr.length;this.index = (++this.index) % len;}}})</script>

这篇关于vue学习十二( v-model用于自定义组件、父子组件通信、组件绑定原生事件、具名插槽、插槽作用域、动态组件is和keep-alive)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1125124

相关文章

Vue3 的 shallowRef 和 shallowReactive:优化性能

大家对 Vue3 的 ref 和 reactive 都很熟悉,那么对 shallowRef 和 shallowReactive 是否了解呢? 在编程和数据结构中,“shallow”(浅层)通常指对数据结构的最外层进行操作,而不递归地处理其内部或嵌套的数据。这种处理方式关注的是数据结构的第一层属性或元素,而忽略更深层次的嵌套内容。 1. 浅层与深层的对比 1.1 浅层(Shallow) 定义

HarmonyOS学习(七)——UI(五)常用布局总结

自适应布局 1.1、线性布局(LinearLayout) 通过线性容器Row和Column实现线性布局。Column容器内的子组件按照垂直方向排列,Row组件中的子组件按照水平方向排列。 属性说明space通过space参数设置主轴上子组件的间距,达到各子组件在排列上的等间距效果alignItems设置子组件在交叉轴上的对齐方式,且在各类尺寸屏幕上表现一致,其中交叉轴为垂直时,取值为Vert

Ilya-AI分享的他在OpenAI学习到的15个提示工程技巧

Ilya(不是本人,claude AI)在社交媒体上分享了他在OpenAI学习到的15个Prompt撰写技巧。 以下是详细的内容: 提示精确化:在编写提示时,力求表达清晰准确。清楚地阐述任务需求和概念定义至关重要。例:不用"分析文本",而用"判断这段话的情感倾向:积极、消极还是中性"。 快速迭代:善于快速连续调整提示。熟练的提示工程师能够灵活地进行多轮优化。例:从"总结文章"到"用

JS常用组件收集

收集了一些平时遇到的前端比较优秀的组件,方便以后开发的时候查找!!! 函数工具: Lodash 页面固定: stickUp、jQuery.Pin 轮播: unslider、swiper 开关: switch 复选框: icheck 气泡: grumble 隐藏元素: Headroom

这15个Vue指令,让你的项目开发爽到爆

1. V-Hotkey 仓库地址: github.com/Dafrok/v-ho… Demo: 戳这里 https://dafrok.github.io/v-hotkey 安装: npm install --save v-hotkey 这个指令可以给组件绑定一个或多个快捷键。你想要通过按下 Escape 键后隐藏某个组件,按住 Control 和回车键再显示它吗?小菜一碟: <template

【 html+css 绚丽Loading 】000046 三才归元阵

前言:哈喽,大家好,今天给大家分享html+css 绚丽Loading!并提供具体代码帮助大家深入理解,彻底掌握!创作不易,如果能帮助到大家或者给大家一些灵感和启发,欢迎收藏+关注哦 💕 目录 📚一、效果📚二、信息💡1.简介:💡2.外观描述:💡3.使用方式:💡4.战斗方式:💡5.提升:💡6.传说: 📚三、源代码,上代码,可以直接复制使用🎥效果🗂️目录✍️

【前端学习】AntV G6-08 深入图形与图形分组、自定义节点、节点动画(下)

【课程链接】 AntV G6:深入图形与图形分组、自定义节点、节点动画(下)_哔哩哔哩_bilibili 本章十吾老师讲解了一个复杂的自定义节点中,应该怎样去计算和绘制图形,如何给一个图形制作不间断的动画,以及在鼠标事件之后产生动画。(有点难,需要好好理解) <!DOCTYPE html><html><head><meta charset="UTF-8"><title>06

学习hash总结

2014/1/29/   最近刚开始学hash,名字很陌生,但是hash的思想却很熟悉,以前早就做过此类的题,但是不知道这就是hash思想而已,说白了hash就是一个映射,往往灵活利用数组的下标来实现算法,hash的作用:1、判重;2、统计次数;

第10章 中断和动态时钟显示

第10章 中断和动态时钟显示 从本章开始,按照书籍的划分,第10章开始就进入保护模式(Protected Mode)部分了,感觉从这里开始难度突然就增加了。 书中介绍了为什么有中断(Interrupt)的设计,中断的几种方式:外部硬件中断、内部中断和软中断。通过中断做了一个会走的时钟和屏幕上输入字符的程序。 我自己理解中断的一些作用: 为了更好的利用处理器的性能。协同快速和慢速设备一起工作

禁止平板,iPad长按弹出默认菜单事件

通过监控按下抬起时间差来禁止弹出事件,把以下代码写在要禁止的页面的页面加载事件里面即可     var date;document.addEventListener('touchstart', event => {date = new Date().getTime();});document.addEventListener('touchend', event => {if (new