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和React受控组件的区别小结

《Vue和React受控组件的区别小结》本文主要介绍了Vue和React受控组件的区别小结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学... 目录背景React 的实现vue3 的实现写法一:直接修改事件参数写法二:通过ref引用 DOMVu

Java使用Javassist动态生成HelloWorld类

《Java使用Javassist动态生成HelloWorld类》Javassist是一个非常强大的字节码操作和定义库,它允许开发者在运行时创建新的类或者修改现有的类,本文将简单介绍如何使用Javass... 目录1. Javassist简介2. 环境准备3. 动态生成HelloWorld类3.1 创建CtC

Java实现将HTML文件与字符串转换为图片

《Java实现将HTML文件与字符串转换为图片》在Java开发中,我们经常会遇到将HTML内容转换为图片的需求,本文小编就来和大家详细讲讲如何使用FreeSpire.DocforJava库来实现这一功... 目录前言核心实现:html 转图片完整代码场景 1:转换本地 HTML 文件为图片场景 2:转换 H

C#使用Spire.Doc for .NET实现HTML转Word的高效方案

《C#使用Spire.Docfor.NET实现HTML转Word的高效方案》在Web开发中,HTML内容的生成与处理是高频需求,然而,当用户需要将HTML页面或动态生成的HTML字符串转换为Wor... 目录引言一、html转Word的典型场景与挑战二、用 Spire.Doc 实现 HTML 转 Word1

Vue3绑定props默认值问题

《Vue3绑定props默认值问题》使用Vue3的defineProps配合TypeScript的interface定义props类型,并通过withDefaults设置默认值,使组件能安全访问传入的... 目录前言步骤步骤1:使用 defineProps 定义 Props步骤2:设置默认值总结前言使用T

Vite 打包目录结构自定义配置小结

《Vite打包目录结构自定义配置小结》在Vite工程开发中,默认打包后的dist目录资源常集中在asset目录下,不利于资源管理,本文基于Rollup配置原理,本文就来介绍一下通过Vite配置自定义... 目录一、实现原理二、具体配置步骤1. 基础配置文件2. 配置说明(1)js 资源分离(2)非 JS 资

Unity新手入门学习殿堂级知识详细讲解(图文)

《Unity新手入门学习殿堂级知识详细讲解(图文)》Unity是一款跨平台游戏引擎,支持2D/3D及VR/AR开发,核心功能模块包括图形、音频、物理等,通过可视化编辑器与脚本扩展实现开发,项目结构含A... 目录入门概述什么是 UnityUnity引擎基础认知编辑器核心操作Unity 编辑器项目模式分类工程

聊聊springboot中如何自定义消息转换器

《聊聊springboot中如何自定义消息转换器》SpringBoot通过HttpMessageConverter处理HTTP数据转换,支持多种媒体类型,接下来通过本文给大家介绍springboot中... 目录核心接口springboot默认提供的转换器如何自定义消息转换器Spring Boot 中的消息

Python学习笔记之getattr和hasattr用法示例详解

《Python学习笔记之getattr和hasattr用法示例详解》在Python中,hasattr()、getattr()和setattr()是一组内置函数,用于对对象的属性进行操作和查询,这篇文章... 目录1.getattr用法详解1.1 基本作用1.2 示例1.3 原理2.hasattr用法详解2.

Python自定义异常的全面指南(入门到实践)

《Python自定义异常的全面指南(入门到实践)》想象你正在开发一个银行系统,用户转账时余额不足,如果直接抛出ValueError,调用方很难区分是金额格式错误还是余额不足,这正是Python自定义异... 目录引言:为什么需要自定义异常一、异常基础:先搞懂python的异常体系1.1 异常是什么?1.2