(vue基础试炼_05)简单组件之间的传值

接上一篇:(vue基础试炼_04)使用组件改造TodoListhttps://gblfy.blog.csdn.net/article/details/103844256

文章目录

  • 一、上篇回顾
    • ① 代码欣赏
    • ② 代码分析
  • 二、子组件如何向父组件传值呢?
    • ① 需求案例文档
    • ② 需求案例效果图
    • ③ 思考与思路
    • ④ 页面验证是否生效
  • 三、删除与数据
    • ① 点击对应的内容,然后删除,又应该怎样做呢?
    • ② 删除思路
    • ③ 模拟删除
    • ④角标删除
    • ⑥ 父子传值总结
    • ⑦ 指令简写

一、上篇回顾

① 代码欣赏

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>使用组件改造TodoList</title><!--引入vue.js库--><script src="vue.js"></script>
</head><body>
<!--vue接管的div-->
<div id="root"><div><input type="text" v-model="inputValue"><button v-on:click="handleBtnClick">提交</button></div><ul><todo-item v-bind:content="item"v-for="item in list"></todo-item></ul>
</div><script>/*创建一个局部组件 TodoItem*/var TodoItem = {props: ['content'],template: "<li>{{content}}</li>"}/*创建了一个vue实例*/var app = new Vue({el: '#root',/*通过对象来注册局部组件TodoItem*/components: {TodoItem: TodoItem},data: {list: [],inputValue: ''},methods: {handleBtnClick: function () {this.list.push(this.inputValue)this.inputValue = ''}}});
</script>
</body>
</html>

② 代码分析

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

序号说明
最外层的父组件就是Vue实例
id等于root的div内容,其实就是最外层Vue实例父组件的模板
我们创建了一个子组件TodoItem子组件
通过todo-item标签的形式,使用了这个子组件
父组件给子组件传值

通过上一篇,大家已经学会了父组件给子组件传值这种方式。
通过v-bind指令将list循环出来的每一项的值item,借助content变量传递todo-tem子组件,子组件通过 props: [‘content’],来接收父组件传递过来的参数值,最后,在模板中通过插值表达式渲染到页面上进行展示!

二、子组件如何向父组件传值呢?

① 需求案例文档

点击列表中的任意一项,进行数据删除

② 需求案例效果图

在这里插入图片描述

③ 思考与思路

这个需求中涉及到了子组件向组件传值的相关知识点了
既然是在子组件中点击内容做的操作,那就给子组件绑定一个事件,当点击事件时,在做逻辑操作即可。

步骤说明
在子组件中绑定一个handleItemClick
在子组件的methods下面写handleItemClick 的方法

在这里插入图片描述

④ 页面验证是否生效

在这里插入图片描述

三、删除与数据

① 点击对应的内容,然后删除,又应该怎样做呢?

② 删除思路

数据在哪存放着呢?父组件的list数组中,父组件决定子组件显示多少个,所以,删除子组件的时候,我们需要点击子组件,子组件把对应的内容传给父组件,让父组件去改变数据,父组件的数据改变了,子组件就会减少或者增加,那具体应该怎样操作呢?
子组件向父组件传值,我们通过this.$emit('delete')向外触发事件
在这里插入图片描述
简述:当我点击子组件时,子组件向外触发一个delete事件,那么,我在父组件里面,创建子组件的同时,可以监听这个delete事件。
在这里插入图片描述
一旦删除事件被触发的时候,就会执行父组件中的handleItemDelete这个方法,因此,我们需要在父组件的methods中定义handleItemDelete这个方法。
在这里插入图片描述

在这里插入图片描述

③ 模拟删除

下面,我们需要做的就是改变list中的数据即可
先让list等于空数组

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>使用组件改造TodoList</title><!--引入vue.js库--><script src="vue.js"></script>
</head><body>
<!--vue接管的div-->
<div id="root"><div><input type="text" v-model="inputValue"><button v-on:click="handleBtnClick">提交</button></div><ul><todo-item v-bind:content="item"v-for="item in list"@delete="handleItemDelete"></todo-item></ul>
</div><script>/*创建一个局部组件 TodoItem*/var TodoItem = {props: ['content'],template: "<li @click='handleItemClick'>{{content}}</li>",methods: {handleItemClick: function () {// alert('click')this.$emit('delete');}}}/*创建了一个vue实例*/var app = new Vue({el: '#root',/*通过对象来注册局部组件TodoItem*/components: {TodoItem: TodoItem},data: {list: [],inputValue: ''},methods: {handleBtnClick: function () {this.list.push(this.inputValue)this.inputValue = ''},handleItemDelete: function () {// alert('click');this.$data.list = []}}});
</script>
</body>
</html>

在这里插入图片描述

④角标删除

删除是实现了但是,删除了所有,那怎样删除指定的内容呢?如果获取内容的角标就好了,我们就可以根据角标删除。
当父组件箱子组件传值的时候,不能只传content,在传一个内容的下标,在子组件中再添加一个下标index,等会作为删除的角标;当父组件传递下标时也许要在子组件中接收。

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>使用组件改造TodoList</title><!--引入vue.js库--><script src="vue.js"></script>
</head><body>
<!--vue接管的div-->
<div id="root"><div><input type="text" v-model="inputValue"><button v-on:click="handleBtnClick">提交</button></div><ul><todo-item v-bind:content="item"v-bind:flag="index"v-for="(item,index) in list"@delete="handleItemDelete"></todo-item></ul>
</div><script>/*创建一个局部组件 TodoItem*/var TodoItem = {props: ['content', 'flag'],template: "<li @click='handleItemClick'>{{content}}</li>",methods: {handleItemClick: function () {// alert('click')this.$emit('delete', this.flag);}}}/*创建了一个vue实例*/var app = new Vue({el: '#root',/*通过对象来注册局部组件TodoItem*/components: {TodoItem: TodoItem},data: {list: [],inputValue: ''},methods: {handleBtnClick: function () {this.list.push(this.inputValue);this.inputValue = ''},handleItemDelete: function (flag) {// alert(flag);// this.$data.list = []this.list.splice(flag, 1)}}});
</script>
</body>
</html>

⑥ 父子传值总结

父组件给子组件传值:通过v-bind借助变量给子组件传值,子组件要在props中进行接收
子组件给父组件传值:我们通过$emit向上触发事件,子组件触发的事件,父组件恰好在监听,接收监控后,父组件就可以接收到子组件传递过来的内容,来实现子组件相符组件传值的功能。

⑦ 指令简写

指令简写
v-on:@
v-bind::

在这里插入图片描述
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/521864.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

漫画:程序员战力图鉴

戳蓝字“CSDN云计算”关注我们哦&#xff01;看漫画了解程序员战斗力 are u ready&#xff1f;编程架构能力撕比嘴炮能力划水摸鱼能力花式甩锅能力画饼忽悠能力PPT吹比能力哈哈哈哈哈哈程序员哥哥上面说的是你吗 福利扫描添加小编微信&#xff0c;备注“姓名公司职位”&#xf…

Python数据挖掘与机器学习,快速掌握聚类算法和关联分析

摘要&#xff1a;前文数据挖掘与机器学习技术入门实战与大家分享了分类算法&#xff0c;在本文中将为大家介绍聚类算法和关联分析问题。分类算法与聚类到底有何区别&#xff1f;聚类方法应在怎样的场景下使用&#xff1f;如何使用关联分析算法解决个性化推荐问题&#xff1f;本…

评分9.7!这本Python书彻底玩大了?程序员:真香!

「超级星推官/每周分享」是一个围绕程序员生活、学习相关的推荐栏目。CSDN出品&#xff0c;每周发布&#xff0c;暂定5期。关键词&#xff1a;靠谱&#xff01;优质&#xff01;本期内容&#xff0c;我们将抽1人送出由我司程序员奉为“超级神作”的《疯狂Python讲义》1本&#…

vs 如何将源文件转换成可执行文件_如何将手机便签转换成word文本文档

如何将手机便签转换成word文本文档&#xff1f;实际上&#xff0c;很多手机自带的便签&#xff0c;虽然可以将单条便签内容&#xff0c;以文字或者图片的形式分享到xxx云文档&#xff0c;但却很少有支持直接转换成Word文档的。一般情况下&#xff0c;他们需要将手机便签里的内容…

端上智能——深度学习模型压缩与加速

摘要&#xff1a;随着深度学习网络规模的增大&#xff0c;计算复杂度随之增高&#xff0c;严重限制了其在手机等智能设备上的应用。如何使用深度学习来对模型进行压缩和加速&#xff0c;并且保持几乎一样的精度&#xff1f;本文将为大家详细介绍两种模型压缩算法&#xff0c;并…

jvm调优 java_opt_Java-100天知识进阶-JVM调优工具-JDK自带工具-知识铺《八》

原标题&#xff1a;Java-100天知识进阶-JVM调优工具-JDK自带工具-知识铺《八》JVM 监控分析工具一、JDK 自带工具1. jconsoleJDK/bin 目录下&#xff0c; jconsole.exe 双击打开&#xff0c; 自动搜索本机运行的虚拟机进程。选择其中一个进程即可&#xff0c;开始进行JVM监控1.…

这帮吃货程序猿,给阿里食堂来了一波骚操作

我叫宋爽&#xff0c;在别人眼里&#xff0c;我是一个程序猿。 别的程序猿&#xff0c;喜欢摁键盘&#xff0c;我嘛&#xff0c;就喜欢吃。 有一次&#xff0c;去医院体检&#xff0c;拿到CT片的我&#xff0c;看着自己的脊椎骨&#xff0c;脑子中一直在想&#xff1a;啊&#…

linux 查看shell脚本执行了多长时间

步骤说明命令①写一个1.sh脚本vim1.sh&#xff0c;把脚本内容复制进去②赋予1.sh可执行权限chmod u_x 1.sh③把要执行的命令复制到第4行&#xff0c;保存退出esc :wq④执行脚本./1sh⑤查看执行脚本&#xff0c;共消耗多长时间基础脚本模板 #!/bin/bash starttimedate %Y-%m-%d…

任正非表示华为可以向美国企业转让5G技术;谷歌同意支付5亿欧元买断与法国纠纷;京东公布iPhone11系列预售战报……...

关注并标星星CSDN云计算极客头条&#xff1a;速递、最新、绝对有料。这里有企业新动、这里有业界要闻&#xff0c;打起十二分精神&#xff0c;紧跟fashion你可以的&#xff01;每周三次&#xff0c;打卡即read更快、更全了解泛云圈精彩newsgo go go 联想举办YOGA 2019秋季新品品…

Tensorflow快餐教程(1) - 30行代码搞定手写识别

摘要&#xff1a; Tensorflow入门教程1去年买了几本讲tensorflow的书&#xff0c;结果今年看的时候发现有些样例代码所用的API已经过时了。看来自己维护一个保持更新的Tensorflow的教程还是有意义的。这是写这一系列的初心。快餐教程系列希望能够尽可能降低门槛&#xff0c;少讲…

科普帖:什么是服务网格?

戳蓝字“CSDN云计算”关注我们哦&#xff01;译| 风车云马文| Josh Fruhlinger来源| InfoWorld网站在数字化转型的背景下&#xff0c;IT行业正在将大型的应用程序集成到小的、离散的微服务容器中&#xff0c;这些容器包含所有的服务代码和依赖项&#xff0c;而这些依赖项彼此独…

年轻人,你为什么来阿里做技术?

摘要&#xff1a; 一个阿里IT男&#xff0c;成了母婴专家? 最近&#xff0c;阿里算法工程师拉普当上了爸爸。 两个月前他就开始为这件事忙活。自从老婆有喜之后&#xff0c;七大姑八大姨都来给他提供参考&#xff0c;生过孩子的朋友、同事都对他说什么该买&#xff0c;主管也时…

查一个字段中字符集超过30的列_详细解读MySQL的30条军规

一、基础规范&#xff08;1&#xff09;必须使用InnoDB存储引擎 解读&#xff1a;支持事务、行级锁、并发性能更好、CPU及内存缓存页优化使得资源利用率更高&#xff08;2&#xff09;必须使用UTF8字符集 解读&#xff1a;万国码&#xff0c;无需转码&#xff0c;无乱码风险&am…

ThinkPHP 5使用OSS

摘要&#xff1a; ThinkPHP 5使用OSS示例。准备工作登录阿里云官网&#xff0c;将鼠标移至产品找到并单击对象存储OSS打开OSS产品详情页面。在OSS产品详情页中的单击立即开通。开通服务后&#xff0c;在OSS产品详情页面单击管理控制台直接进入OSS管理控制台界面。您也可以单击位…

Linux环境_源码安装LibreOffice实现文件在线预览doc,doxc,xls,xlsx,ppt,pptx 文件

因业务需求需要&#xff0c;利用LibOffice可以打开的文档的转换。 服务器版本 环境系统版本LinuxRed Hat Enterprise Linux Server release 7.6 (Maipo)LinuxCentOS Linux release 7.6 需要准备软件包 软件及版本下载链接LibreOffice_6.3.2_Linux_x86-64_rpm.tar.gzhttps://w…

关于云原生需要了解什么

戳蓝字“CSDN云计算”关注我们哦&#xff01;尽管随处可闻云原生&#xff0c;却鲜少有人告诉你到底什么是云原生&#xff0c;若是找资料来看&#xff0c;读完大多会感觉云缭雾绕&#xff0c;一知半解&#xff0c;总之虚得很&#xff0c;甚至会让你一度怀疑自己的智商&#xff0…

仅使用NumPy完成卷积神经网络CNN的搭建(附Python代码)

摘要&#xff1a; 现有的Caffe、TensorFlow等工具箱已经很好地实现CNN模型&#xff0c;但这些工具箱需要的硬件资源比较多&#xff0c;不利于初学者实践和理解。因此&#xff0c;本文教大家如何仅使用NumPy来构建卷积神经网络&#xff08;Convolutional Neural Network , CNN&a…

SpringBoot 使用LibreOffice 在线预览 doc,doxc,xls,xlsx,ppt,pptx 文件

接上一篇&#xff1a;linux环境源码安装unoconv Linux环境_源码安装Unoconv实现文件在线预览doc&#xff0c;doxc&#xff0c;xls&#xff0c;xlsx&#xff0c;ppt&#xff0c;pptx 文件 https://gblfy.blog.csdn.net/article/details/103540694 接上一篇&#xff1a;linux环境…

裸辞面11家python公司,拿到4个offer!网友:买了简历置顶会员吗?

我一直认为&#xff0c;敢裸辞的只有2种人&#xff1a;1、能力足够强&#xff0c;即使裸辞也不会被财务问题所困&#xff0c;更不愁找工作。2、年轻气盛&#xff0c;遇到傻X领导和傻X同事&#xff0c;绝对0容忍&#xff01;但是最近我在刷某乎的时候&#xff0c;发现了第三种人…

万用表怎么测电池内阻_数字万用表和指针万用表,两者怎么选?

​万用表又称为复用表、多用表、三用表、繁用表等&#xff0c;一般以测量电压、电流和电阻为主要目的。是一种多功能、多量程的测量仪表&#xff0c;可测量直流电流、直流电压、交流电流、交流电压、电阻和音频电平等&#xff0c;有的还可以测交流电流、电容量、电感量及半导体…