好家伙,

1.组件的props

props是组件的自定义属性,在封装通用组件的时候,合理的使用props可以极大的提高组件的复用性

来假设一下,如果我们需要两个组件分别显示不同的值

目录结构如下:

HelloWorld.vue中,

  <div>

   <h2>我的init值为{{ init }}</h2>

  </div>
</template> <script>
export default {
//props指向一个数组,
//允许使用者通过自定义属性,为当前的组件指定初始值
//定义属性的名字,是封装这自定义的(只要合法即可)
props:['init'],
}
</script> <style> </style>

Left.vue中,

<template>
<div>
<h1>我是Left组件</h1>
<HelloWorld init="5"/> </div>
</template>

Right.vue中,

<template>
<div>
<h1>我是Right组件</h1>
<HelloWorld init="10"/>
</div>
</template>

App.vue中

<template>
<div id="app"> <Left/>
<Right/> </div>
</template> <script> import Left from './components/Left.vue'
import Right from './components/Left.vue'
export default {
name: 'App',
components: { Left,
Right
}
}
</script>

对了,main.js中还需要对HelloWorld组件进行全局注册

import HelloWorld from './components/HelloWorld.vue'

Vue.component('HelloWorld',HelloWorld)

效果如下:

2.对props使用v-bind

若我们将前面的

<HelloWorld init="10">

改为

<HelloWorld :init="10"/>

那么这里的init中的10就是数字10

可进行计算处理的数字10

而原先的"10"是字符串

(下图可见两者区别)

 

3.props的值是只读的

vue规定:组件中封装的自定义属性是只读的,程序员不能直接修改props的值,否则会直接报错

 
 

4.实践

好了,现在我们来实现一个经典点击自增一按钮

(太TM经典了)

<template>
<div> <h2>我的init值为{{ count }}</h2>
<button @click="count += 1">加一</button>

</div>
</template> <script>
export default {
props:['init'],

 //count可读可写,所以使用count来进行自增操作
data(){
return{
count:this.init
}
},
}
</script>

效果如下:

上面是字符字符类型的init

下面是数值类型的init

5.props的default默认值

改为对象形式的props

props:{

    //自定义属性A:{/*配置选项*/}
//自定义属性B:{/*配置选项*/}
//自定义属性C:{/*配置选项*/}
init:{
//若果外界使用Count组件的时候,没有传递init属性,则默认值生效
default:10
}
},

当未对init的值进行设定时,默认为10

6.props的type值类型

在声明自定义属性时,可以通过type来定义属性的值类型.示例代码如下:

props:{

    init:{
//若果外界使用Count组件的时候,没有传递init属性,则默认值生效
default: 10, //init值的类型必须是Number数字
type:Number, }
},

7.props的required必填项

required校验你是否传值

若未传值,则报错,(即使有默认值的存在)

props:{

    init:{
//若果外界使用Count组件的时候,没有传递init属性,则默认值生效
default: 10, //init值的类型必须是Number数字
type:Number, //必须项校验
required:true }
},

That's all

第七十二篇:Vue组件的props的更多相关文章

  1. 前端(二十二)—— vue组件:局部组件、全局组件、父组件数据传到子组件、子组件数据传到父组件、父子组件实现todoList

    Vue组件 一.组件介绍 每一个组件都是一个vue实例 每个组件均具有自身的模板template,根组件的模板就是挂载点,根组件也可以显式书写模板,会替换掉挂载点 每个组件模板只能拥有一个根标签 子组 ...

  2. 第三十二篇:vue的响应式原理

    好家伙 什么是响应式?比较官方的回答: Vue.js 的核心包括一套"响应式系统". "响应式",是指当数据改变后,Vue 会通知到使用该数据的代码. 例如,视 ...

  3. Spring Cloud第十二篇 | 消息总线Bus

    ​ ​本文是Spring Cloud专栏的第十二篇文章,了解前十一篇文章内容有助于更好的理解本文: Spring Cloud第一篇 | Spring Cloud前言及其常用组件介绍概览 Spring ...

  4. Python开发【第二十二篇】:Web框架之Django【进阶】

    Python开发[第二十二篇]:Web框架之Django[进阶]   猛击这里:http://www.cnblogs.com/wupeiqi/articles/5246483.html 博客园 首页 ...

  5. 跟我学SpringCloud | 第十二篇:Spring Cloud Gateway初探

    SpringCloud系列教程 | 第十二篇:Spring Cloud Gateway初探 Springboot: 2.1.6.RELEASE SpringCloud: Greenwich.SR1 如 ...

  6. Egret入门学习日记 --- 第十二篇(书中 5.1节 内容)

    第十二篇(书中 5.1节 内容) 昨天把 第4章完成了. 今天来看第5章. 接下来是 5.1节 的内容. 总结一下 5.1节 的重点: 1.如何制作一个公用按钮皮肤. 跟着做: 重点1:如何制作一个公 ...

  7. TNFE-Weekly[第七十二周已更新]

    前端行业发展飞速,新技术如雨后春笋般快速出现,尤其是各种小程序陆续推出,相关的信息.文章也铺天盖地的遍布在各处,我们有时候会困惑,不知道哪些信息对于自己是有价值的,那么TNFE-腾讯新闻前端团队启动了 ...

  8. vue第十二单元(vue中过渡效果的实现)

    第十二单元(vue中过渡效果的实现) #课程目标 熟练掌握transition组件的用法 熟练使用transition组件做过渡特效 熟练使用transition组件做动画特效 了解使用transit ...

  9. 13. 第十二篇 二进制安装kubelet

    文章转载自:https://mp.weixin.qq.com/s?__biz=MzI1MDgwNzQ1MQ==&mid=2247483842&idx=1&sn=1ef1cb06 ...

随机推荐

  1. 18.Tomcat部署及优化

    Tomcat部署及优化 目录 Tomcat部署及优化 Tomcat简介 Tomcat核心组件 Web容器 什么是 servlet? 什么是 JSP? Container 结构分析 Tomcat 请求过 ...

  2. SAP Web Dynpro-使用服务调用

    创建服务调用后,功能模块可用于组件. 现在可以选择一个视图,以便在浏览器中显示数据库表的元素. 如果全局控制器不是组件控制器,则必须为所选视图的控制器输入全局控制器的使用页面. 之后,应该有该节点的映 ...

  3. EasyExcel使用

    将下面三层结合起来,请放心食用. 一.controller层 @RestController public class EasyExcelController { private Logger log ...

  4. 零基础学Java(1)初识Java程序

    前言 就国内来说,Java毫无疑问是后端语言中的No.1没有之一,所以今天我们也来0基础学习Java!!! Java的好处(针对测试工程师) 面试加分->涨薪 大多数公司服务端用的都是Java, ...

  5. 腾讯云数据库公有云市场稳居TOP 2!

    7月4日,国际权威机构IDC发布的<2021年下半年中国关系型数据库软件市场跟踪报告>显示,腾讯云数据库在关系型数据库软件市场(公有云模式)中,位列第二. IDC报告显示,2021下半年中 ...

  6. jupyter 反向代理配置

    抓了下包,看了一下WS连不上,参考这个,问题解决 location / { proxy_pass http://127.0.0.1:8813/; # JUPYTER_PORT 为 Jupyter 运行 ...

  7. Markdown扩展语法

    目录 Markdown 语法补充 一.快速生成 HTML 表格代码 在线表格编辑器--TablesGenerator 二. 插入视频.音频或GIF 1. 视频 2. 音频 方法一 方法二 方法三 3. ...

  8. 水电表/压力表/传感器/流量计/行车记录仪/分贝仪等 超低功耗LCD段码液晶驱动IC-VKL076(VKL系列)SSOP28 19*4COM,工作电流约7.5微安

    产品品牌:永嘉微电/VINKA 产品型号:VKL076 封装形式:SSOP28 产品年份:新年份 概述: VKL076 SSOP28是一个点阵式存储映射的LCD驱动器,可支持最大76点(19SEGx4 ...

  9. angular 变化检测和ngZone

  10. 2022-7-25 第七组 pan小堂 多态

    多态 多态是继封装.继承之后,面向对象的第三大特性. 现实事物经常会体现出多种形态,如学生,学生是人的一种,则一个具体的同学张三既是学生也是人,即出现两种形态. Java作为面向对象的语言,同样可以描 ...