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

相关文章

部署Vue项目到服务器后404错误的原因及解决方案

《部署Vue项目到服务器后404错误的原因及解决方案》文章介绍了Vue项目部署步骤以及404错误的解决方案,部署步骤包括构建项目、上传文件、配置Web服务器、重启Nginx和访问域名,404错误通常是... 目录一、vue项目部署步骤二、404错误原因及解决方案错误场景原因分析解决方案一、Vue项目部署步骤

Android 悬浮窗开发示例((动态权限请求 | 前台服务和通知 | 悬浮窗创建 )

《Android悬浮窗开发示例((动态权限请求|前台服务和通知|悬浮窗创建)》本文介绍了Android悬浮窗的实现效果,包括动态权限请求、前台服务和通知的使用,悬浮窗权限需要动态申请并引导... 目录一、悬浮窗 动态权限请求1、动态请求权限2、悬浮窗权限说明3、检查动态权限4、申请动态权限5、权限设置完毕后

前端原生js实现拖拽排课效果实例

《前端原生js实现拖拽排课效果实例》:本文主要介绍如何实现一个简单的课程表拖拽功能,通过HTML、CSS和JavaScript的配合,我们实现了课程项的拖拽、放置和显示功能,文中通过实例代码介绍的... 目录1. 效果展示2. 效果分析2.1 关键点2.2 实现方法3. 代码实现3.1 html部分3.2

Java深度学习库DJL实现Python的NumPy方式

《Java深度学习库DJL实现Python的NumPy方式》本文介绍了DJL库的背景和基本功能,包括NDArray的创建、数学运算、数据获取和设置等,同时,还展示了如何使用NDArray进行数据预处理... 目录1 NDArray 的背景介绍1.1 架构2 JavaDJL使用2.1 安装DJL2.2 基本操

java父子线程之间实现共享传递数据

《java父子线程之间实现共享传递数据》本文介绍了Java中父子线程间共享传递数据的几种方法,包括ThreadLocal变量、并发集合和内存队列或消息队列,并提醒注意并发安全问题... 目录通过 ThreadLocal 变量共享数据通过并发集合共享数据通过内存队列或消息队列共享数据注意并发安全问题总结在 J

CSS弹性布局常用设置方式

《CSS弹性布局常用设置方式》文章总结了CSS布局与样式的常用属性和技巧,包括视口单位、弹性盒子布局、浮动元素、背景和边框样式、文本和阴影效果、溢出隐藏、定位以及背景渐变等,通过这些技巧,可以实现复杂... 一、单位元素vm 1vm 为视口的1%vh 视口高的1%vmin 参照长边vmax 参照长边re

CSS3中使用flex和grid实现等高元素布局的示例代码

《CSS3中使用flex和grid实现等高元素布局的示例代码》:本文主要介绍了使用CSS3中的Flexbox和Grid布局实现等高元素布局的方法,通过简单的两列实现、每行放置3列以及全部代码的展示,展示了这两种布局方式的实现细节和效果,详细内容请阅读本文,希望能对你有所帮助... 过往的实现方法是使用浮动加

css渐变色背景|<gradient示例详解

《css渐变色背景|<gradient示例详解》CSS渐变是一种从一种颜色平滑过渡到另一种颜色的效果,可以作为元素的背景,它包括线性渐变、径向渐变和锥形渐变,本文介绍css渐变色背景|<gradien... 使用渐变色作为背景可以直接将渐China编程变色用作元素的背景,可以看做是一种特殊的背景图片。(是作为背

Java使用POI-TL和JFreeChart动态生成Word报告

《Java使用POI-TL和JFreeChart动态生成Word报告》本文介绍了使用POI-TL和JFreeChart生成包含动态数据和图表的Word报告的方法,并分享了实际开发中的踩坑经验,通过代码... 目录前言一、需求背景二、方案分析三、 POI-TL + JFreeChart 实现3.1 Maven

CSS自定义浏览器滚动条样式完整代码

《CSS自定义浏览器滚动条样式完整代码》:本文主要介绍了如何使用CSS自定义浏览器滚动条的样式,包括隐藏滚动条的角落、设置滚动条的基本样式、轨道样式和滑块样式,并提供了完整的CSS代码示例,通过这些技巧,你可以为你的网站添加个性化的滚动条样式,从而提升用户体验,详细内容请阅读本文,希望能对你有所帮助...