| |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
-> JavaScript知识库 -> Vue插槽的使用(匿名插槽、具名插槽、作用域插槽)以及ElementUI中table-column的slot-scope应用(scope.row、scope.$index、scope.column) -> 正文阅读 |
|
[JavaScript知识库]Vue插槽的使用(匿名插槽、具名插槽、作用域插槽)以及ElementUI中table-column的slot-scope应用(scope.row、scope.$index、scope.column) |
先说说插槽的使用:(才疏学浅,白话表述)可以把插槽理解为组件B中留下的一个坑,谁用这个坑谁就可以往里面填放东西,同时呢,谁也就要认组件B做儿子-----组件B也就成了这个来填坑的组件的子组件。 插槽不单单是可以让父组件用它填充东西,也可以引用子组件的数据,而父组件用坑的时候也就可以用子组件传过来的数据。 单个插槽(默认插槽、匿名插槽)子组件:(slotdemoson.vue)
?父组件:(slotdemo.vue)---既然使用子组件的插槽就的先import引入子组件
只引用了子组件,但是没有使用子组件的插槽,那么插槽中如果有内容会默认显示出来 使用子组件的插槽,父组件要填坑了(给子组件里面加<template>来使用插槽),子组件不变,父组件修改代码如下:
会发现:子组件代码不变,父组件使用给<template>中加入了一段文字,这段文字直接把子组件中的<slot>插槽中的文字替换了。——如果子组件有插槽而父组件使用子组件但不使用插槽,插槽内容默认展示;如果父组件使用了插槽,以父组件的填充内容为主。 提示:匿名插槽由于没有任何自身标识,所以建议子组件中只使用一次,如果使用多次,当父组件写了一个<template>***</template>的时候,将会给子组件中所有的匿名插槽都填充为***。 具名插槽(有具体名字,有标识的插槽)可以根据名字来有针对性的使用插槽子组件:(slotdemoson.vue)
父组件:(只更新了template部分,省略了子组件的引入等代码)
可以看到只是在使用子组件时,向其内部的结构标签div中加上了slot属性并指向了子组件中定义的插槽的插槽名,就把这个div按照对应的插槽名替换成子组件中的插槽了 如果把多个结构都指向了同一个插槽名,那么会把这些数据都渲染出来,后面的不会覆盖前面的? 作用域插槽(可视为携带数据的匿名插槽)没名,但可以携子组件的数据带给父组件子组件:(通过 :数据别名=“数据” 来给到插槽,将数据绑定给这个插槽)
父组件:(通过给template加 slot-scope 属性) 这里会将slot-scope属性的属性值作为一个对象-----用于保存子组件插槽中绑定的数据 这个用于保存插槽数据的slot-scope的属性值要通过子组件插槽定义的数据别名来访问数据
scope.fruits实际可以拿到子组件的数据:Fruits? 父组件对插槽带来的数据进行遍历,并将数组元素渲染到页面上;
????????数据在组件本身上,通过插槽将数据做以绑定共享,数据要在什么结构中怎样使用就看使用者(父组件)了。 这几天在用Vue+ElementUI完成一个项目时,用到了作用域插槽。 场景就是:需要根据服务器响应来的数据渲染成一个表格到页面上,而表格中每一行的后面都有个操作列,可以对这一行的数据进行修改、删除等。一提到对这一行的数据进行修改、删除就必然得获取到这一行数据中的唯一标识(俗话说就是ID),那在ElementUI中就给table-column赋予了一项技能,就是使用插槽,ElementUI预设了三个参数(row, column, $index)。 可以通过插槽中定义的接收数据的对象来调用,调用row也就可以获取到这一行的数据,再从中提取id也就拿到了这一行数据所对应的id值,也就可以根据id向服务器发起修改或删除的请求了。 这里做以简化,假设Fruits就是服务器响应的数据,并将其绑定给el-table,ElementUI提供了一个很nice的功能:给表<el-table>的列<el-table-column>使用作用域插槽,可以通过slot-scope的属性值来调用row获取这一行的数据。 组件template 代码:
组件script?代码:(这里Fruits的数据格式要参考ElementUI中的表格引用的数据格式)
?组件style 代码:
页面渲染效果: (可见这一行的数据都可以拿到,当涉及通过ID对这一行数据进行删改时,ID的获取不是事儿)? ElementUI-table官方文档?最下面有这个插槽功能的解释 ↓: 如果是scope.column会得到这一列的信息: ?如果是scope.$index会得到这一行是第几行(索引): |
|
JavaScript知识库 最新文章 |
ES6的相关知识点 |
react 函数式组件 & react其他一些总结 |
Vue基础超详细 |
前端JS也可以连点成线(Vue中运用 AntVG6) |
Vue事件处理的基本使用 |
Vue后台项目的记录 (一) |
前后端分离vue跨域,devServer配置proxy代理 |
TypeScript |
初识vuex |
vue项目安装包指令收集 |
|
上一篇文章 下一篇文章 查看所有文章 |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 | -2025/1/10 1:23:56- |
|
网站联系: qq:121756557 email:121756557@qq.com IT数码 |