Vue--第八天

Vue3

1.优点:

2.创建:

3.文件:

换运行插件:

4.运行:

setup函数:

setup函数中获取不到this(this 在定义的时候是Undefined)

reactive()和ref():

代码:

<script setup>

// reactive :接收一个对象类型的数据。返回一个响应式的对象

import { reactive } from 'vue'

import { ref } from 'vue'

// 只有用 reactive() 包裹的对象才能去响应式改变,否则不能改变

// 倘若是简单类型的对象,我们用ref(),但是这个简单和复杂都可以接受,

// 本质是自动增加了外层对象,使之成为复杂类型,再借助reactive实现的响应式

// 注意点: 1.script中访问数据,需要通过 .value

// 2.template 中不用,因为自动加了.value

// 推荐  数据定义同一用ref()

const state = reactive({

  count: 100

})

const stateTwo = ref(10)

const setCount = () => {

  state.count++

}

const setCountRef = () => {

  stateTwo.value++

}

</script>

<template>

  <div>

    <div>{{ state.count }}</div>

    <div>{{ stateTwo.value }}</div>

    <button @click="setCount">+1</button>

    <button @click="setCountRef">+1</button>

  </div>

</template>

<style></style>

computed:

有读和写两种方法:get 和 set ,但是我们一般用只读,改的话另外写函数

<script setup>

import { ref, computed } from 'vue'

const list = ref([1, 2, 3, 4, 5, 6, 7, 8, 9])

const computedList = computed(() => {

  // 在这里拿值别忘了 .value

  return list.value.filter(item => item > 5)

})

</script>

<template>

  <div>

    <div>计算后属性:{{ computedList }}</div>

  </div>

</template>

<style></style>

watch函数:

侦听不要加value,我们侦听对象,不是单个数字

immediate:
deep:

代码:

<script setup>

import { ref, watch } from 'vue'

const count = ref(0)

const nickname = ref('张三')

const changeName = () => {

  nickname.value = '李四'

}

const changeCount = () => {

  count.value++

}

// 1.单个对象   这个新值老值是函数固定好了的,不是我们想改就能改的

// watch( count,(newValue,oldValue) => {

//    console.log( newValue,oldValue)

// })

// 2.多个对象

// watch([count,nickname], (newArr,oldArr) =>{

//   console.log(newArr,oldArr)

// })

// 3.immediate: 一进页面就执行,从空数组变为有值的数组

// watch([count, nickname], (newArr,oldArr) => {

//   console.log(newArr,oldArr)

// },{

//    immediate: true

// })

// 4.deep 深度监视默认 watch进行的是浅层监视

// 1.const ref1 = ref(简单类型)可以直接监视

// 2.const ref2 = ref(复杂类型)监视不到复杂类型内部数据的变化

const userInfo = ref({

  name: '张三',

  age: 18

})

const setUserInfo = () => {

  userInfo.value.age++

}

watch(userInfo, (newValue) => {

  console.log(newValue)

}, {

  immediate: true,

  // 不加deep 监视不到对象

  deep: true

})

</script>

<template>

  <div>

    <div>{{ count }}</div>

    <button @click="changeCount">数字</button>

    <div>{{ nickname }}</div>

    <button @click="changeName">昵称</button>

    <div>{{ userInfo }}</div>

    <button @click="setUserInfo">年龄+1</button>

  </div>

</template>

<style></style>

精准监听:

代码:

// 5.对于对象中的属性,进行精准监听,不确定加没加imediate函数

watch(() => userInfo.value.age,(newValue, oldValue) => {

  console.log(oldValue, newValue)

})

5.周期函数:

代码:

<script setup>

import { onMounted } from 'vue';

const getList = () => {

  setTimeout(() => {

    console.log('发送请求获取数据')

  },2000)

}

getList()

// 如果有写代码需要在mounted生命周期中执行

onMounted(() => {

  console.log('mounted生命周期,可以提供多个')

})

</script>

<template>

  <div></div>

</template>

<style></style>

6.父子通信

代码:

<script setup>

import { ref, onMounted } from 'vue'

import sonCom from '@/components/sonCom.vue'

const money = ref(101)

const getMoney = () => {

  money.value = money.value + 10

}

const getList = () => {

  setTimeout(() => {

    console.log('发送请求获取数据')

  },2000)

}

const changeFn = (use) => {

  money.value = money.value - use

}

getList()

// 如果有写代码需要在mounted生命周期中执行

onMounted(() => {

  console.log('mounted生命周期,可以提供多个')

})


 

</script>

<template>

  <div>

    <sonCom car = '宝马车'

    :money="money"

    @changeMoney = 'changeFn'>

  </sonCom>

  </div>

  <button @click="getMoney">挣钱</button>

</template>

<style></style>

<script setup>

// 子组件

// 在这里接收父组件的方式需要借助 '编译器宏'函数,感觉还是以对象的形式封装

const props = defineProps({

    car: String,

    money: Number

})

console.log(props.car)

console.log(props.money)

const emit = defineEmits(['changeMoney'])

const delMoney = () => {

    // 需要emit触发事件

    emit('changeMoney',10)

}

</script>

<template>

    <!-- 对于props传递来的数据,模板中可以直接使用,不用去接收.动态传值也一样 -->

    <div>{{ car }}--{{ money }}</div>

    <div class='son'>我是子组件</div>

    <button @click='delMoney'>花钱</button>

</template>

<style>

.son {

    height: 300px;

    width: 300px;

    border: 2px;

    background-color: greenyellow;

}

</style>

7.模板引用:

通过ref标识获取真实的dom对象或者组件实例对象

代码:

<script setup>

// 模板引用

// 1.调用函数,生成ref对象

// 2.通过ref标识,进行绑定

// 3.通过ref对象.value即可访问到绑定的元素

import {onMounted, ref} from 'vue'

const inp = ref(null)

onMounted(() =>{

  // console.log(inp.value.focus())

  // inp.value.focus()

})

const clickFn = () => {

  inp.value.focus()

}

</script>

<template>

<div>

  <input ref="inp" type = 'text'>

  <button @click="clickFn">点击输入框聚焦</button>

</div>

</template>

<style></style>

8.provide 和inject 

10.defineOptions:

11. v-model 和 defineModel:

需要有如下配置:

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

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

相关文章

解决el-table组件中,分页后数据的勾选、回显问题?

问题描述&#xff1a; 1、记录一个弹窗点击确定按钮后&#xff0c;table列表所有勾选的数据信息2、再次打开弹窗&#xff0c;回显勾选所有保存的数据信息3、遇到的bug&#xff1a;切换分页&#xff0c;其他页面勾选的数据丢失&#xff1b;点击确认只保存当前页的数据&#xff1…

学习MS Dynamics AX 2012编程开发 1. 了解Dynamics AX 2012

在本章中&#xff0c;您将了解开发环境的结构以及Microsoft Dynamics AX中的开发人员可以访问哪些工具。在本书的第一步演练之后&#xff0c;您将很容易理解著名的Hello World代码&#xff0c;您将知道应用程序对象树中的不同节点代表什么。 以下是您将在本章中学习的一些主题…

圆形多线图

const gaugeData [{value: 80,name: Perfect,title: {offsetCenter: [-100%, -100%]},detail: {valueAnimation: true,offsetCenter: [-70%, -100%]},itemStyle: {borderColor: #fff,borderWidth: 6,borderType: solid // 可选&#xff0c;指定边框类型}},{value: 40,name: Go…

MQ-Det: Multi-modal Queried Object Detection in the Wild

首个支持视觉和文本查询的开放集目标检测方法 NeurIPS2023 文章&#xff1a;https://arxiv.org/abs/2305.18980 代码&#xff1a;https://github.com/YifanXu74/MQ-Det 主框图 摘要 这篇文章提出了MQ-Det&#xff0c;一种高效的架构和预训练策略&#xff0c;它利用文本描述的…

JS的箭头函数this:

箭头函数不会创建自己的this&#xff0c;它只会从自己的作用域链的上一层沿用this。 具体看实例&#xff1a; //以前&#xff1a;谁调用的这个函数 this就指向谁// console.log(this);//window// function fn(){// console.log(this);//window 因为这个函数也是window调用…

【Vue+Python】—— 基于Vue与Python的图书管理系统

文章目录 &#x1f356; 前言&#x1f3b6;一、项目描述✨二、项目展示&#x1f3c6;三、撒花 &#x1f356; 前言 【VuePython】—— 基于Vue与Python的图书管理系统 &#x1f3b6;一、项目描述 描述&#xff1a; 本项目为《基于Vue与Python的图书管理系统》&#xff0c;项目…

hive的分区表和分桶表详解

分区表 Hive中的分区就是把一张大表的数据按照业务需要分散的存储到多个目录&#xff0c;每个目录就称为该表的一个分区。在查询时通过where子句中的表达式选择查询所需要的分区&#xff0c;这样的查询效率会提高很多。 静态分区表基本语法 创建分区表 create table dept_p…

Android 移动端编译 cityhash动态库

最近做项目&#xff0c; 硬件端 需要 用 cityhash 编译一个 动态库 提供给移动端使用&#xff0c;l 记录一下 编译过程 city .cpp // // Created by Administrator on 2023/12/12. // // Copyright (c) 2011 Google, Inc. // // Permission is hereby granted, free of charg…

54 代码审计-TP5框架审计写法分析及代码追踪

目录 知识点1知识点2演示案例:demo代码段自写和规则写分析hsycms-TP框架-不安全写法-未过滤weipan21-TP框架-规则写法-内置过滤 知识点1 调试&#xff0c;访问&#xff0c;路由&#xff0c;配置&#xff0c;版本等 知识点2 自写写法&#xff1a;自己写代码&#xff0c;一步步…

以csv为源 flink 创建paimon 临时表相关 join 操作

目录 概述配置关键配置测试启动 kyuubi执行配置中的命令 bug解决bug01bug02 结束 概述 目标&#xff1a;生产中有需要外部源数据做paimon的数据源&#xff0c;生成临时表&#xff0c;以使用与现有正式表做相关统计及 join 操作。 环境&#xff1a;各组件版本如下 kyuubi 1.8…

互联网加竞赛 python 爬虫与协同过滤的新闻推荐系统

1 前言 &#x1f525; 优质竞赛项目系列&#xff0c;今天要分享的是 &#x1f6a9; python 爬虫与协同过滤的新闻推荐系统 &#x1f947;学长这里给一个题目综合评分(每项满分5分) 难度系数&#xff1a;3分工作量&#xff1a;3分创新点&#xff1a;4分 该项目较为新颖&…

迅速理解什么是通信前置机

通信前置机设在两个通信对象之间&#xff0c;是实质性的物理服务器&#xff0c;适应不同通信协议或数据格式之间的相互转换。 前置机的作用&#xff1a; 隔离——隔离客户端与服务端&#xff0c;保障后端安全减负——处理非核心业务&#xff0c;分担后端服务器压力&#xff0…

Microsoft 365 Copilot正式上线,如何稳定访问体验?

如果将微软对人工智能的投资看成一场豪赌&#xff0c;Microsoft Copilot无疑是现阶段最受瞩目的赌注。2023年9月正式发布的Microsoft Copilot是一种基于大型语言模型&#xff08;LLM&#xff09;和微软图形&#xff08;Microsoft Graph&#xff09;的数据和人工智能&#xff08…

Maven环境搭建及配置

Maven环境搭建及配置 1.下载部署 官方网站下载正式版的Maven文件,打开bin目录&#xff0c;复制路径然后去环境变量中的path下配置环境变量&#xff0c; 如果只有一个用户只需要在上面path配置复制的路径,当然也可以直接在下面配置,下面配置默认给所有用户都配置 设置完成打开控…

MIT线性代数笔记-第28讲-正定矩阵,最小值

目录 28.正定矩阵&#xff0c;最小值打赏 28.正定矩阵&#xff0c;最小值 由第 26 26 26讲的末尾可知在矩阵为实对称矩阵时&#xff0c;正定矩阵有以下四种判定方法&#xff08;都是充要条件&#xff09;&#xff1a; 所有特征值都为正左上角所有 k k k阶子矩阵行列式都为正&…

软考科目如何选择?

软考科目繁多&#xff0c;让许多学弟学妹感到困惑&#xff0c;不知道该选择哪个科目。以下是一些建议&#xff0c;可以根据个人实际需求选择备考的科目。 1、初级是可选的 软考初级非常简单&#xff0c;适合刚刚入门学习的朋友报考。对于一些有基础的朋友&#xff0c;建议直接…

【后端开发】Next.js 13.4:前端开发的游戏规则改变者!

自我介绍 做一个简单介绍&#xff0c;酒架年近48 &#xff0c;有20多年IT工作经历&#xff0c;目前在一家500强做企业架构&#xff0e;因为工作需要&#xff0c;另外也因为兴趣涉猎比较广&#xff0c;为了自己学习建立了三个博客&#xff0c;分别是【全球IT瞭望】&#xff0c;【…

微服务实战系列之MQ

前言 从今天起&#xff0c;席卷北国的雪&#xff0c;持续了一整天&#xff0c;北京也不例外。这场意外的寒潮&#xff0c;把整个冬天渲染的格外cool。当然你可以在外面打雪仗、堆雪人、拉雪橇&#xff0c;也可以静坐屋内&#xff0c;来一场围炉煮茶的party。此刻&#xff0c;冬…

世界第一个语言不通的人是如何沟通的?

引言&#xff1a;语言是人类交流的重要工具&#xff0c;但在人类历史的某个时刻&#xff0c;肯定会有这样一位勇敢的先驱&#xff0c;他成为了世界上第一个语言不通的人。那么在他面临交流难题时&#xff0c;他是如何与他人沟通的呢&#xff1f;本文将对此进行探索。主体&#…

18 5G - NR物理层解决方案支持6G非地面网络中的高移动性

文章目录 非地面网络场景链路仿真参数实验仿真结果 非地面网络场景 链路仿真参数 实验仿真结果 Figure 5 && Figure 6&#xff1a;不同信噪比下的BER和吞吐量 变量 SISO 2x2MIMO 2x4MIMO 2x8MIMOReyleigh衰落、Rician衰落、多径TDL-A(NLOS) 、TDL-E(LOS)(a)QPSK (b)16…