当前位置: 首页 > wzjs >正文

网站侧边栏设计专业的网络推广

网站侧边栏设计,专业的网络推广,网站建设服务描述,上海专业产品摄影标签的ref属性 vue3和vue2中的ref属性: 用在普通DOM标签上,获取的是DOM节点 ref用在组件标签上,获取的是组件实例对象 区别在于: 1.vue3中person子组件中的数据父组件App不能直接使用,需要引入并使用defineExpose才可…

标签的ref属性

vue3和vue2中的ref属性:
用在普通DOM标签上,获取的是DOM节点
ref用在组件标签上,获取的是组件实例对象
区别在于:
1.vue3中person子组件中的数据父组件App不能直接使用,需要引入并使用defineExpose才可以;
vue2中person子组件中的数据父组件App可直接使用。
2.vue2中获取节点:
<h2 ref="title">重庆</h2>
this.$refs.title
vue2中获取组件实例对象:
<Person ref="per"/>
this.$refs.per
3.vue3中的获取语法见以下代码:

<template><div class="app"><h2>大理</h2><h2 ref="title">重庆</h2><h2>大西北</h2><button @click="getDOM">点我获取节点</button></div>
</template><script lang="ts" setup name="Person">//知识点:标签的ref属性    用于获取DOM元素或者组件实例对象时使用// 要求一:获取重庆这条信息的DOM节点import { ref,defineExpose } from "vue"let title=ref()function getDOM(){console.log(title.value)}// 要求二:获取组件实例对象(代码见App组件)// 要求三:在person组件里添加一些数据// 解析:在vue3中,person组件中的数据App组件如果想要使用需要引入并使用defineExpose才可以。(defineExpose也可以不引用,直接使用)let a= ref(0)let b= ref(1)let c= ref(2)defineExpose({a,b,c})   //这样父组件就获取到了person里的数据
</script>

App.vue组件

<template><Person ref="per"/><button @click="getPerson">点我获取person组件实例</button>
</template><script lang="ts" setup name="App">import Person from "./components/Person.vue"  // 只需引入,不用注册组件,vue3引入之后会自动注册import {ref} from "vue"// 要求二:获取组件实例对象let per=ref()function getPerson(){console.log(per.value)} 
</script>

TS接口、泛型、自定义类型

**作用:**提升代码的可靠性、可维护性和开发效率

<template><div class="app"><h2>{{ person.name }}</h2><h2>{{ personlist[1].name }}</h2></div>
</template><script lang="ts" setup name="Person">
import {type personInter,type persons} from "../types"
// TS的接口、泛型、自定义类型    // 作用:给代码设置一定的约束,防止出错// 知识点一:TS的接口   
// ====================================================================//要求一:给person对象设置一定的约束//首先创建types文件夹,定义接口 let person:personInter={id:"asycs01",name:"李华",age:18}// 这样使用接口之后,如果打错单词或者属性类型会给提示// ====================================================================// 知识点二:TS的泛型  <>//要求二:给personlist数组设置一定的约束let personlist:Array<personInter>=[{id:"asycs01",name:"李华",age:18},{id:"asycs02",name:"小明",age:20},{id:"asycs03",name:"小红",age:21}]// ====================================================================// 知识点三:TS的自定义类型  <>//要求三:基于要求二的高级写法(见index.ts)let personlist1:persons=[{id:"asycs01",name:"李华",age:18},{id:"asycs02",name:"小明",age:20},{id:"asycs03",name:"小红",age:21}]
// ====================================================================// 知识点四:需要使用reactive时的写法://要求四:要将数组中的数据变为响应式的数据let personlist2=reactive<persons>([{id:"asycs01",name:"李华",age:18},{id:"asycs02",name:"小明",age:20},{id:"asycs03",name:"小红",age:21}])
</script>

types/index.ts:

// 定义接口
export interface personInter{id:string,name:string,age:number,gender?:string   //当想要给某一个对象添加性别时这样写,但如果写成gender:string就要给每一个属性都添加gender
}
// export type persons=Array<personInter>
export type persons=personInter[]

父亲给儿子传递参数

App.vue

<template><Person :personList="personList"/>
</template><script lang="ts" setup name="App">import Person from "./components/Person.vue"// 只需引入,不用注册组件,vue3引入之后会自动注册import {type persons} from "./types"import {reactive} from "vue"let personList=reactive<persons>([{id:"asycs01",name:"李华",age:18},{id:"asycs02",name:"小明",age:20},{id:"asycs03",name:"小红",age:21}])</script>

Person.vue

<template><div class="app"><ul><li v-for="item in personList" :key="item.id">{{ item.name }}</li></ul></div>
</template><script lang="ts" setup name="Person">
import {type persons} from "../types"
import { withDefaults } from "vue";
// ===========================================================
//知识点一:defineProps 接收数据// 要求一:将App中的数据传递给Person// defineProps(["personList"])// ===========================================================//知识点二:defineProps 接收数据并限制接收数据的类型// defineProps<{personList:persons}>()  // {}中第一个参数是接收的对象,第二个参数是接口规范// ===========================================================//知识点三:defineProps 接收数据并限制接收数据的类型并限制必要性// defineProps<{personList?:persons}>() // ===========================================================//知识点三:defineProps 接收数据并限制接收数据的类型并限制必要性withDefaults(defineProps<{personList?:persons}>(),{personList:()=>[{id:"asycs01",name:"李华",age:18},{id:"asycs02",name:"小明",age:20}]})
</script>

文章转载自:

http://82vavx3e.rqxtb.cn
http://bqvgOpz4.rqxtb.cn
http://ujFFdA91.rqxtb.cn
http://b54ebocT.rqxtb.cn
http://HRKzakla.rqxtb.cn
http://t22jrXBF.rqxtb.cn
http://99PkD1C0.rqxtb.cn
http://yCllqZLu.rqxtb.cn
http://fZQxNbC1.rqxtb.cn
http://PcyzCwjj.rqxtb.cn
http://5tBj6tWW.rqxtb.cn
http://8xZGKtAt.rqxtb.cn
http://u5S0cg8g.rqxtb.cn
http://Vj9V7LKM.rqxtb.cn
http://CT4NqSTb.rqxtb.cn
http://PKXhEXei.rqxtb.cn
http://M2PsANIC.rqxtb.cn
http://lzAiPs2o.rqxtb.cn
http://GgeCd93B.rqxtb.cn
http://yIi7sOOe.rqxtb.cn
http://3Y8p7Pgl.rqxtb.cn
http://AJwBlqY1.rqxtb.cn
http://dKmcbqUi.rqxtb.cn
http://xeolv0fN.rqxtb.cn
http://sCaQtU7T.rqxtb.cn
http://6XEllorm.rqxtb.cn
http://aWBq4x5d.rqxtb.cn
http://7YA0j4ED.rqxtb.cn
http://cggZh3vv.rqxtb.cn
http://NG9AVsOG.rqxtb.cn
http://www.dtcms.com/wzjs/642101.html

相关文章:

  • 建材企业网站推广软件公司开发
  • 桂林网站制作多少钱厦门网站优化推广
  • 吉林智能网站建设价格网站建设需要哪种人才
  • 百度在线做网站jsp网站开发的使用表格
  • 网站建设it职位海天建设集团有限公司网站
  • 网站建设宣传软文范例优化营商环境建议
  • 工作室网站备案wordpress固定链接找不到
  • 手机跳转网站建设青岛联通网站备案
  • 滑雪网站的建设综合网站开发
  • 在线域名查询网站高端网站建设公司有必要做吗
  • 推广网站怎么做能增加咨询网站制作外包
  • 购物网站源码下载站长工具永久更新
  • 网站备案幕布照片wordpress服务器镜像
  • 河南5G网站基站建设信息网站服务公司
  • 成都网站建设冠辰广告公司的网站建设
  • 网站建设推进会讲话稿建手机网站公司
  • 深圳网站设计x程序东莞网络推广外包托管
  • 营销型网站设计注意查询网网站
  • 网站代码 公告栏 php关键词优化一年多少钱
  • 常州市金坛区网站建设wordpress主题修改头部
  • 杭州门户网站建设微信小程序代码大全
  • 怎么给设计网站推广南京网站搭建
  • dede小说网站模板下载网站全屏广告
  • 代理加盟网站asp.net做网站视频
  • 做外账要登什么网站郑州商城网站制作
  • 无水印做海报的网站东莞南城网站设计
  • 网站开发公司地址wordpress匿名头像
  • 住房和城乡建设部执法网站在服务器网站上做跳转页面
  • 高培淇自己做的网站凡客诚品倒闭了吗
  • 网站建设步骤电脑2018年期刊网站建设调查