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

湛江建设免费网站广州商旅网站制作

湛江建设免费网站,广州商旅网站制作,网页生成pdf不显示,怎么做自己的微信网站什么是侦听器 个人理解#xff1a;当有一个响应式状态#xff08;普通变量 or 一个响应式对象#xff09;发生改变时#xff0c;我们希望监听到这个改变#xff0c;并且能够进行一些逻辑处理。那么侦听器就是来帮助我们实现这个功能的。侦听器 其实就是两个函数#xff…什么是侦听器 个人理解当有一个响应式状态普通变量 or 一个响应式对象发生改变时我们希望监听到这个改变并且能够进行一些逻辑处理。那么侦听器就是来帮助我们实现这个功能的。侦听器 其实就是两个函数watch() 或者是 watchEffect() 。 watch() 的特点 被侦听的数据源非常明确逻辑代码与被侦听的数据源相互独立可维护性较好 watchEffect() 的特点出现在这里边的响应式状态就会被监听就是被监听的数据源 和 逻辑代码 写在一起了watchEffect() 的监听是立即执行的不是非得等到值发生改变时才开始执行。下面通过案例来体会一下它们的用法。watch 侦听器 语法格式 watch(被监听的响应式状态(新值旧值){ 逻辑代码 },{可选的配置对象}) 一共有 三个参数 参数1 指定被监听的状态可以是一个变量或对象 参数2 监听到之后的响应回调函数 参数3 其他的属性配置可选的不是很常用 【注意】    watch第一个参数可以同时监听多个状态写成数组的形式但是笔者不建议这样使用如果想监听多个状态可以分开一个一个的写嘛。 watch 监听一个 ref 的普通响应式状态 这是最基本的使用直接上代码: 一个文本输入框 一个普通的响应式变量 当文本输入框中的内容发生改变时在侦听器的逻辑中修改 普通变量的值。 template!-- 监听器的使用 --div!-- 普通的响应式状态 --textValue : input typetext v-modeltextValuebrotherValue1 : {{ orhterValue1 }} br/div/templatescript setup langtsimport { ref,watch } from vue// 声明一个 文本输入框的值const textValue ref(这是文本输入框)// 声明一个 变量当 textValue 发生变化时这个变量也发生变化const orhterValue1 ref()// 监听 textValue 这个变量的状态变化watch(textValue,(newValue:string,oldValue:string){console.log(oldValue is ${oldValue})console.log(newValue is ${newValue})console.log(textValue is ${textValue.value})// 当textValue 的值发生改变时我们修改 otherValue1 的值orhterValue1.value 改变了new Date().getTime()})/scriptstyle scoped /style运行效果 初始状态文本框改变之后 watch 监听一个reactive的响应式对象 当想监听一个对象是否发生改变时需要使用reactive 创建响应式对象 而且这个监听是深度监听即无论这个对象的属性有多少层都能够被监听到 而且监听的回调函数的两个参数都是一样的全都是新值对象因为这就是一个对象这一条可能比较晦涩难懂记住就行了 案例 有一个响应式的对象 有一个按钮 点击按钮改变对象的某个属性触发侦听器的逻辑 template!-- 监听器的使用 --div!-- 监听一个对象 --stu : {{ stu }}brbutton clickchangeStu点击修改对象的属性/button/div/templatescript setup langtsimport { reactive,watch } from vue// 声明一个响应式的对象const stu reactive({id:100,name:小红,classInfo:{classId:001,className:快乐足球一班}})// 修改对象的属性的方法const changeStu (){stu.classInfo.className 拒绝踢足球二班}// 监听对象发生了变化 : 需要使用 reactive// 且此处的 newValue 和 oldValue 是一样的因为它是一个对象都是更新后的值watch(stu,(newValue,oldValue){console.log(oldValue is ,oldValue)console.log(newValue is ,newValue)console.log(stu is ,newValue)})/scriptstyle scoped /style运行效果 watch 监听一个对象的某个属性 通过 getter 方法的形式将对象的属性作为被侦听的对象。 getter方法 其实就是写一个简单的函数返回被侦听的对象。 这种监听无论是 ref 还是 reactive 声明的响应式对象都是可以的。 案例 有一个响应式的对象 有一个按钮 点击按钮改变对象的某个属性触发侦听器的逻辑 template!-- 监听器的使用 --div!-- 监听一个对象的其中的某个属性 --stu : {{ stu }}brbutton clickchangeStu点击修改对象的属性/button/div/templatescript setup langtsimport { reactive,watch } from vue// 声明一个响应式的对象const stu reactive({id:100,name:小红,classInfo:{classId:001,className:快乐足球一班}})// 修改对象的属性的方法const changeStu (){stu.classInfo.className 拒绝踢足球二班}// 通过getter 函数的方式监听对象某个属性的值watch(() stu.classInfo.className,(newValue,oldValue){console.log(oldValue is ,oldValue)console.log(newValue is ,newValue)console.log(stu is ,newValue)})/scriptstyle scoped/style运行效果 watchEffect侦听器 特点 只要是出现在 watchEffect 中的响应式的状态就会被纳入监听 当响应式状态发生改变时会自动触发侦听器的逻辑。 它可以比较方便的监听多个状态值但是只要有一个值触发了就会把整个的侦听逻辑执行一遍 案例 一个文本输入框可以监听文本输入框的值 一个按钮点击修改 对象的一个属性该属性被侦听器监听 template!-- 监听器的使用 --div!-- 普通的响应式状态 --textValue : input typetext v-modeltextValuebrhr!-- 监听一个对象 --stu : {{ stu }}brbutton clickchangeStu点击修改对象的属性/button/div/templatescript setup langtsimport { ref,reactive,watchEffect} from vue// 声明一个 文本输入框的值const textValue ref(这是文本输入框)// 声明一个响应式的对象const stu reactive({id:100,name:小红,classInfo:{classId:001,className:快乐足球一班}})// 修改对象的属性的方法const changeStu (){stu.classInfo.className 拒绝踢足球二班}// 通过 watchEffect 进行监听watchEffect((){// 监听普通的属性if(textValue.value.length 7){console.log(检测到了 textValue 属性的修改)console.log(textValue : ,textValue.value)console.log(---------------)}// 监听对象的属性if(stu.classInfo.className.length 6){console.log(检测到了className属性的修改)console.log(className : ,stu.classInfo.className)console.log(---------------)}})/scriptstyle scoped /style运行效果
http://www.hkea.cn/news/14511424/

相关文章:

  • 建设公司网站需要准备哪些材料宁波优化网站排名公司推荐
  • 想学网站制作代刷网站只做软件
  • 建设美团网站江苏备案网站名称
  • 水果门户网站建设网络需求分析的主要内容有哪些
  • 林州网站建设哪家专业中国企业500强门槛
  • 长沙专业网站建设服务网站首次备案 多久
  • 西安做网站的公司维护网站后台管理系统有哪些
  • 深圳网站开发公司 有哪些wordpress悬浮按钮插件
  • icp主体备案号和网站备案号天津平台网站建设推荐
  • php学校网站源码深圳市门户网站建设怎么样
  • 网站域名301是什么意思短网址短链接生成器
  • 网站的权限设置专业网站制作推荐
  • 北京好网站制作公司哪家好杭州哪家网站建设好
  • 网站建设全部代码哈尔滨建设网站门户
  • 中信建投证券股份有限公司seo文章是什么
  • 网站建设和管理情况自查报告中国设计网室内
  • 辽宁东方建设工程有限公司网站电脑做网站怎么解析域名
  • 桃城网站建设代理手机2345网址大全
  • 网站建设及经营应解决好的问题安卓系统上怎样做网站前端开发
  • 桂林北站地图wordpress优化教程
  • 做网站一般像素青岛建设集团官方网站
  • 360可以做网站营销推广是干什么的
  • 营销型网站建设的特点wordpress漂流瓶插件
  • 免费网站制作软件wordpress erphpdown
  • 食品网站建设项目的预算wordpress设置tdk
  • 网站建设优化保定东莞网站竞价推广运营
  • 广汉网站建设ghxhwl北京网站设计公司价格
  • 江西省建设招标网站做哪个网站最简单
  • 目前做网站最流行的程序语言做网站一天能接多少单
  • 仁怀网站建设网络工程师需要学哪些知识