Vue--第八天

news2024/9/21 0:48:06

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.coloradmin.cn/o/1304317.html

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

相关文章

springboot listener、filter登录实战

转载自&#xff1a; www.javaman.cn 博客系统访问&#xff1a; http://175.24.198.63:9090/front/index 登录功能 1、前端页面 采用的是layui-admin框架&#xff0c;文中的验证码内容&#xff0c;请参考作者之前的验证码功能 <!DOCTYPE html> <html lang"zh…

如何通过VNC实现公网远程控制macOS设备

&#x1f337;&#x1f341; 博主猫头虎&#xff08;&#x1f405;&#x1f43e;&#xff09;带您 Go to New World✨&#x1f341; &#x1f984; 博客首页——&#x1f405;&#x1f43e;猫头虎的博客&#x1f390; &#x1f433; 《面试题大全专栏》 &#x1f995; 文章图文…

Pinia无废话,快速上手

Pinia无废话&#xff0c;快速上手 Vue3 状态管理 - Pinia 1. 什么是Pinia Pinia 是 Vue 的专属的最新状态管理库 &#xff0c;是 Vuex 状态管理工具的替代品 2. 手动添加Pinia到Vue项目 后面在实际开发项目的时候&#xff0c;Pinia可以在项目创建时自动添加&#xff0c;现…

PDI/Kettle-9.4.0.0-343源码下载及编译

目录 &#x1f351;一、概要&#x1f34a;最新版本10.x&#xff08;2023-11-30&#xff09; &#x1f351;二、下载&#x1f351;三、编译&#x1f34a;3.1、导入开发工具&#x1f34a;3.2、开始编译&#x1f34a;3.3、编译报错&#x1f34a;3.4、报错原因&#xff1a;jdk版本低…

if - else 实现点击展开 / 折叠

在前端开发过程中&#xff0c;我们经常需要使用到点击展开/折叠的按钮。 此案例是一个数组嵌套数组的效果展示&#xff0c;使用的是v-if else 来实现的展开效果。 一、实现方法 if...else&#xff1a;当指定条件为真&#xff0c;if 语句会执行一段语句。如果条件为假&#x…

2023/12/11 作业

1.思维导图 2.作业 成果&#xff1a; 第一个头文件 #ifndef TEST3GET_H #define TEST3GET_H #include <QWidget> #include<QMessageBox> QT_BEGIN_NAMESPACE namespace Ui { class test3get; } QT_END_NAMESPACE class test3get : public QWidget { Q_OBJE…

用docker创建jmeter容器,如何实现性能测试?

用 docker 创建 jmeter 容器, 实现性能测试 我们都知道&#xff0c;jmeter可以做接口测试&#xff0c;也可以用于性能测试&#xff0c;现在企业中性能测试也大多使用jmeter。docker是最近这些年流行起来的容器部署工具&#xff0c;可以创建一个容器&#xff0c;然后把项目放到…

chrome浏览器使用flash player

今天用chrome打开学校校园网&#xff0c;显示不出来成绩单提示如下&#xff1a; 结果下了也没用。 Chrome浏览器在2020年12月已经停止支持Flash Player插件&#xff0c;所以无法在Chrome浏览器上使用Flash Player。 使用其他浏览器 如果之前安装了Flash Player插件的小伙伴&…

多维时序 | MATLAB实现SAO-CNN-BiGRU-Multihead-Attention多头注意力机制多变量时间序列预测

多维时序 | MATLAB实现SAO-CNN-BiGRU-Multihead-Attention多头注意力机制多变量时间序列预测 目录 多维时序 | MATLAB实现SAO-CNN-BiGRU-Multihead-Attention多头注意力机制多变量时间序列预测预测效果基本介绍模型描述程序设计参考资料 预测效果 基本介绍 MATLAB实现SAO-CNN-B…

关于引用unpkg.com的mars3d相关依赖文件报错无法请求的说明

问题来源&#xff1a; 1.关于引用unpkg.com的mars3d相关依赖文件报错无法请求的说明 说明&#xff1a; 1.最近npm、unpkeg都访问异常&#xff0c;可能是unpkg.com等国外的服务器不稳定导致的请求未响应。 解决方案&#xff1a; 1.请切换静态文件引入的方式请求相关资源。参…

Science Robotics 挖掘机升级智能机器人,充分使用当地材料自主搭建石墙和土墙

建筑业对人类生产力至关重要&#xff0c;但需要实质性创新来满足不断增长的需求并减少其对环境的严重影响。建筑业是世界上最大的经济部门之一&#xff0c;占全球国内生产总值的13%。推而广之&#xff0c;它几乎是所有其他行业的重要组成部分&#xff1a;建筑业负责运输和农业基…

定时补偿方案

1&#xff1a;需求描述 支持NVR升级后通道数变更&#xff0c;完成升级后&#xff0c;设备SDK上报通道数量给A平台&#xff0c;A平台将NVR通道数量同步给B平台&#xff0c;B平台自动调用C平台接口&#xff0c;同步通道数量给C平台&#xff0c;C平台重新生成通道序列号&#xff…

PHP 之道(PHP The Right Way 中文版)

PHP 之道&#xff08;PHP The Right Way 中文版&#xff09;

HeartBeat监控Mysql状态

目录 一、概述 二、 安装部署 三、配置 四、启动服务 五、查看数据 一、概述 使用heartbeat可以实现在kibana界面对 Mysql 服务存活状态进行观察&#xff0c;如有必要&#xff0c;也可在服务宕机后立即向相关人员发送邮件通知 二、 安装部署 参照章节&#xff1a;监控组件…

液态二氧化碳储存罐远程无线监测系统

二氧化碳强化石油开采技术&#xff0c;须先深入了解石油储层的地质特征和二氧化碳的作用机制。现场有8辆二氧化碳罐装车&#xff0c;每辆罐车上有4台液态二氧化碳储罐&#xff0c;每台罐的尾部都装有一台西门子S7-200 smart PLC。在注入二氧化碳的过程中&#xff0c;中控室S7-1…

租一台服务器多少钱决定服务器的价格因素有哪些

租一台服务器多少钱决定服务器的价格因素有哪些 大家好我是艾西&#xff0c;服务器这个名词对于不从业网络行业的人们看说肯定还是比较陌生的。在21世纪这个时代发展迅速的年代服务器在现实生活中是不可缺少的一环&#xff0c;平时大家上网浏览自己想要查询的信息等都是需要服…

terser

环境&#xff1a; 一、使用vueCli创建的项目的vue.config.js 添加terser配置 验证了在打包后生成的.js文件中确实没有了console.log() 这里的.js.map可以省略&#xff0c;公司里代码打包后就没有.js.map文件了 要配置下除去.js.map文件或者统一分到.map文件夹里 二、vite 安…

抓紧收藏!软考个税抵扣3600元详细操作流程

软考证书有很多项福利政策&#xff0c;“个税补贴 ”是很容易被忽略的一项&#xff0c;但其实这一项也是实打实的资金补贴。 持有软考证书可在线上申请&#xff0c;按照3600定额扣除。 具体操作流程&#xff0c;接下来详细说明。 01 政策依据 根据《个人所得税专项附加扣除暂…

极兔速递查询,极兔速递单号查询,筛选出指定派件员的单号

批量查询极兔速递单号的物流信息&#xff0c;并将指定派件员的单号筛选出来。 所需工具&#xff1a; 一个【快递批量查询高手】软件 极兔速递单号若干 操作步骤&#xff1a; 步骤1&#xff1a;运行【快递批量查询高手】软件&#xff0c;第一次使用的朋友记得先注册&#xff…

ThreadLocal 本地线程变量详解

概述 ThreadLocal 意为本地线程变量&#xff0c;即该变量只属于当前线程&#xff0c;对其他线程隔离 我们知道&#xff0c;一个普通变量如果被多线程访问会存在存在线程安全问题&#xff0c;这时我们可以使用 Synchronize 来保证该变量某一时刻只能有一个线程访问&#xff0c…