【Vue】Vue2基本使用

news2024/10/7 1:37:33

文章目录

    • 一、模板语法
      • 1、插值语法
        • 写法
        • 介绍
      • 2、指令语法
        • 写法
        • 介绍
      • 模板语法示例
    • 二、数据绑定
      • 介绍
      • 数据绑定示例
        • 效果
    • 三、初始化Vue时,`data`属性与`el`属性的两种写法
      • `el`的两种写法
      • `data`的两种写法
      • 演示案例
    • 四、MVVM模型
      • 介绍
    • 五、数据代理
      • JS数据代理
        • 案例演示
      • Vue数据代理
        • 介绍
        • 原理
    • 六、事件处理
      • 事件的基本使用
        • 介绍
        • 演示案例
      • 事件修饰符
        • 六种修饰符
        • 演示案例
      • 键盘事件
        • Vue中常用的按键别名
        • 系统修饰键
        • 自动义按键别名
        • 演示案例
    • 七、计算属性与监听属性
      • 计算属性(computed)
        • 介绍
          • 1)定义
          • 2)原理
          • 3)get函数何时执行
          • 4)优势
          • 5)备注
        • 简写方式
        • 演示案例
      • 监视属性(watch)
        • 说明
        • 监视的两种写法
          • 第一种,new Vue时传入watch配置
          • 第二种, 通过vm.$watch监视
        • 深度监视
          • 演示案例
        • 监视属性的简写方式
        • 备注
          • 案例演示
      • `computed`和`watch`之间的区别
        • 区别
        • 两个重要的小原则
        • 案例演示
    • 八、绑定样式([Class与 Style 绑定](https://cn.vuejs.org/v2/guide/class-and-style.html))
      • 绑定`class`样式
      • 绑定`style`样式
      • 案例演示
    • 九、条件渲染(v-if、v-show)
      • `v-if`
        • 写法
        • 介绍
      • `v-show`
        • 写法
        • 介绍
      • 备注
      • 案例演示
    • 十、列表渲染(v-for)
      • `v-for`指令
        • 写法
        • 介绍
        • 案例演示
      • `key`的原理
        • 虚拟DOM中key的作用
        • 比较规则
        • 用`index`作为`key`可能会引发的问题
        • 开发中如何选择`key`?
        • 遍历列表时key的作用
          • index作为key
          • id作为key
        • 案例演示
      • 列表过滤
        • 案例演示
      • 列表排序
        • 案例演示
    • 十一、Vue怎么监视数据
      • 如何监测对象中的数据?
      • 如何监视数组中的数据?
      • Vue中修改数组元素使用方法
        • 第一种,使数组的7个[变更方法](https://cn.vuejs.org/v2/guide/list.html#变更方法)
          • 1)push(追加)
          • 2)pop(删除最后一个元素)
          • 3)shift(删除第一个元素)
          • 4)unshift(开头添加)
          • 5)splice(删除与添加指定位置的任意个元素)
          • 6)sort(排序)
          • 7)reverse(反转数组)
        • 第二种,使用`Vue.set()`或`vm.$set()`
        • 注意
    • 十二、收集表单数据([表单输入绑定](https://cn.vuejs.org/v2/guide/forms.html))
      • 根据`input`类型绑定数据
      • `v-model`的三个修饰符
      • 案例演示
    • 十三、过滤器
      • 定义
      • 语法
      • 备注
      • 案例演示



一、模板语法


1、插值语法

写法

表达式为任意js表达式,可直接读取到data中的所有属性

<div>{{表达式}}</div>

介绍

插值语法用于解析标签体中的内容。数据绑定最常见的形式就是使用Mustache语法 (双大括号) 进行文本插值,被Mustache标签包裹的对象的值将会插入Mustache标签的位置,并且,无论何时,绑定的数据对象上发生了改变,插值处的内容都会更新

image

但是通过使用 v-once 指令,你也能执行一次性地插值,当数据改变时,插值处的内容不会更新。但请留心这会影响到该节点上的其它数据绑定。

image


2、指令语法

写法

Vue中所有指令格式都是以**v-**开头,例如v-bind。表达式为任意js表达式

v-bind:href="表达式"

介绍

指令语法用于解析标签(包括标签属性、标签体内容、绑定事件……)。指令 (Directives) 是带有 v- 前缀的特殊 attribute。指令 attribute 的值预期是单个 JavaScript 表达式 (v-for 是例外情况)。指令的职责是,当表达式的值改变时,将其产生的连带影响,响应式地作用于 DOM

image

上面例子中,v-if 指令将根据表达式 seen 的值的真假来插入或移除 <p> 元素。从 2.6.0 开始,可以用方括号括起来的 JavaScript 表达式作为一个指令的参数

image

这里的 attributeName 会被作为一个**JavaScript表达式进行动态求值**,求得的值将会作为最终的参数来使用。例如,如果你的 Vue 实例有一个data的属性attributeName,其值为 “href”,那么这个绑定将等价于 v-bind:href


模板语法示例

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>vue模板语法</title>
    <script src="../js/vue.js"></script>
</head>
<!--
    Vue模板语法两大类
    插值语法
      功能:用于解析标签体内容
      写法:<div>{{表达式}}</div>,表达式为任意js表达式,可直接读取到data中的所有属性
    指令语法
      功能:用于解析标签(包括标签属性、标签体内容、绑定事件……)
      写法:v-bind:href="表达式" 表达式为任意js表达式
      备注:Vue中所有指令格式都是以`v-`开头。如v-bind
-->
<body>
    <div id="root">
        <h1>插值语法</h1>
        <h3>你好,{{name}}</h3>
        <hr/>
        <h1>指令语法</h1>
        <a v-bind:href="url">点击跳转链接</a>
        <!--v-bind可以简写为 `:` -->
        <a :href="url">点击跳转链接2</a>
        <!-- 2.6.0开始,等价于:href="url" -->
        <a :[attr]="url">点击跳转链接3</a>
    </div>
</body>
<script>
    new Vue({
        el:"#root",
        data:{
            name:"张三",
            url:'https://www.baidu.com',
            attr:'href'
        }
    })
</script>
</html>




二、数据绑定


介绍

Vue中有两种数据绑定的方式

  • **单向绑定(v-bind):**数据只能从data流向页面
  • **双向绑定(v-model):**数据可以从data流向页面,也可以从页面流向data

其中,双向绑定只能用于表单元素上,对value属性进行绑定(如:input、select等), v-model:value 可以简写为v-model,因为v-model默认收集的就是**value属性**

image


数据绑定示例

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>vue数据绑定</title>
    <script src="../js/vue.js"></script>
</head>
<body>
    <div id="root">
        单项数据绑定(v-bind):<input type="text" v-bind:value="name"/><br/>
        双向数据绑定(v-model):<input type="text" v-model:value="name"/>
        <!--简写-->
        <br/>
        单项数据绑定(v-bind):<input type="text" :value="name"/><br/>
        双向数据绑定(v-model):<input type="text" v-model="name"/>
    </div>
</body>
<script>
    new Vue({
        el:'#root',
        data:{
            name:'张三'
        }
    })
</script>
</html>

效果

GIF 2022-12-12 16-47-44




三、初始化Vue时,data属性与el属性的两种写法


el的两种写法

  • 第一种,new Vue时配置el属性
  • 第二种,先创建Vue实例,再通过实例.$mount('绑定对象')指定el的值

data的两种写法

  • 第一种,对象式写法(new Vue时配置data属性)
  • 第二种,函数式写法(配置data属性时使用的是函数的返回值)
    • 由Vue管理的函数不要写箭头函数,否则this不再指向Vue实例,而是window实例

演示案例

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Vueel与data的两种写法</title>
    <script src="../js/vue.js"></script>
</head>
<body>
    <div id="root">
        <h1>你好,{{name}}</h1>
    </div>
</body>
<script>
    /*
    const vm = new Vue({
                    el:'#root',//el的第一种写法
                    data:{ //data的第一种写法
                        name:'张三'
                    }
                })
    vm.$mount('#root') //el的第二种写法
    */
   new Vue({
       el:'#root',
       data:function(){ //data的第二种写法
           console.log("@@@",this)
           return {name:'李四'}
       }
   })
</script>
</html>




四、MVVM模型


介绍

  • M:模型(model),data中的数据
  • V:视图(View),模板代码
  • VM:视图模型(ViewModel),Vue实例

data中的所有属性,最后都会出现在vm(Vue实例)上,vm(Vue实例)上的所有属性Vue原型的所有属性都可在Vue模板上直接使用




五、数据代理


JS数据代理

通过一个对象代理另外一个对象中的属性的操作叫做数据代理,在JS中使用Object.defineProperty方法实现数据代理。

案例演示

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>回顾Object.defineProperty方法</title>
</head>
<body>
<script>
    let num = 10
    let person = {
        name:'张三',
        sex:'男',
    }
    //为对象追加属性
    Object.defineProperty(person,'age',{
        value:18,//此属性的值
        enumerable:true,//此属性是否可以枚举,默认为false
        writable:true,//此属性是否可修改,默认为false
        configurable:true,//此属性是否可删除,默认为false
    })
    //数据代理,将num属性交于person对象代理
    Object.defineProperty(person,'n',{
        //当调用person的n属性时将返回num的值
        get(){
            console.log('有人读取n属性,值为'+num)
            return num
        },
        //当修改person的n属性改变num的值
        set(value){
            console.log('有人修改n的值,修改值为'+value)
            num = value
        }
    })
    console.log(person)
</script>
</body>
</html>

实现效果

image


Vue数据代理

介绍

通过vm对象代理data对象中属性的操作,好处是更加方便的操作data中的数据

原理

通过**Object.defineProperty()data对象中的所有属性添加到vm对象上,为每个添加到vm上的属性都指定getter/setter方法,在getter/setter内部去操作(读/写)**data中对应的属性




六、事件处理


事件的基本使用

介绍

  • 使用v-on:xxx 或简写为 @xxx 绑定事件,其中xxx为事件名
  • 事件的回调需配置在methods对象中,最终由vm代理
  • methods属性中配置的函数不能是箭头函数!否则this不再执行vm对象
  • methods属性中配置的函数都是被Vue管理的函数,this指向vm或组件实例对象
  • @click="demo""@click="demo($event)"效果是一样的,不过后者可以传其他参数

演示案例

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>事件的基本使用</title>
    <!--引入Vue-->
    <script src="../js/vue.js"></script>
</head>
<body>
    <div id='root'>
        <h2>你好,{{name}}</h2>
        <button v-on:click="showInfo">点我提示信息</button>
        <!--v-on简写为@click-->
        <button @click="showInfo2('你好,世界')">点我提示mes</button>
        <!--没有写参数时默认传递事件信息,也可以写成showInfo3($event)-->
        <button @click="showInfo3">点我显示event信息</button>
    </div>
</body>
<script>
    const vm = new Vue({
        el:'#root',
        data:{
            name:'张三'
        },
        methods:{
            showInfo(){
                alert("同学你好")
            },
            showInfo2(msg){
                alert(msg)
            },
            showInfo3(event){
                console.log(event)
            }
        }
    })
</script>
</html>

实现效果

image


事件修饰符

六种修饰符

  • prevent:阻止默认事件(常用)
  • stop:阻止事件冒泡(常用)
  • once:事件只触发一次(常用)
  • capture:使用事件的捕捉模式
  • self:只有event.target是当前操作的元素时才会触发事件
  • passive:事件的默认行为会立即触发,无需等待事件回调完毕

另外,修饰符可以连续书写,例如:@click.prevent.stop="回调函数"

img-xDuB0a3l-1670852202539


演示案例

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>事件修饰符</title>
    <style>
        *{margin-top: 20px;}
        li{height: 100px;}
    </style>
    <!--引入Vue-->
    <script src="../js/vue.js"></script>
</head>
<body>
    <div id='root'>
        <h2>欢迎来到{{name}}学习</h2>
        <!--阻止默认行为,在这里是阻止跳转到指定网址(常用)-->
        <a href="http://www.baidu.com" @click.prevent="showInfo">点我提示信息</a>
        <!--阻止冒泡事件(常用)-->
        <div @click="showInfo" style="height:50px;background-color:skyblue;">
            <button @click.stop="showInfo">点我提示信息</button>
        </div>
        <!--阻止默认行为的同时阻止冒泡事件-->
        <div @click="showInfo" style="height:50px;background-color:skyblue;">
            <a href="http://www.baidu.com" @click.prevent.stop="showInfo">点我提示信息</a>
        </div>
        <!--事件只触发一次(常用)-->
        <button @click.once="showInfo">点我提示信息</button>
        <!--使用事件的捕捉模式(先捕获事件,然后在从内到外冒泡事件,
            如果不加的话执行事件的顺序为2、1,使用捕获模式是在捕获阶段执行事件,顺序为1、2-->
        <div @click.capture="showInfo(1)" style="height: 70px;background-color: tomato;padding: 2px;">
            div1
            <div @click="showInfo(2)" style="height: 30px;background-color: wheat;">
                div2
            </div>
        </div>
        <!--只有event.target是当前操作的元素时才会触发事件-->
        <div @click.self="showInfo" style="height:50px;background-color:skyblue;">
            <button @click="showInfo">点我提示信息</button>
        </div>
        <!--事件的默认行为会立即触发,无需等待事件回调完毕-->
        <!--wheel:鼠标滚轮滚动事件 scroll:滚动条移动事件-->
        <ul @wheel.passive="demo" style="width: 200px;height: 200px;background-color: peru;overflow: auto;">
            <li>1</li>
            <li>2</li>
            <li>3</li>
            <li>4</li>
        </ul>
    </div>
</body>
<script>
    const vm = new Vue({
        el:'#root',
        data:{
            name:"长沙理工"
        },
        methods:{
            showInfo:function(event){
                alert('欢迎你的到来')
                console.log(event.target)
            },
            demo(){
                //模拟事件体延时
                for(let i=0;i<10000;i++){
                    console.log('@')
                }
                console.log("延迟完成")
            }
        }
    })
</script>
</html>

键盘事件

Vue中常用的按键别名

  • enter(回车)
  • delete(删除和退格键)
  • esc(退出)
  • space(空格)
  • tab(换行,必须要配合keydown事件使用)
  • up(上)
  • down(下)
  • left(左)
  • right(右)

Vue没有提供别名的特殊按键(如CapsLock)可以使用按键名称的去绑定,但注意要转为"小写单词-小写单词"的格式(如caps-lock)

按键修饰符也能连续使用,例如:@keyup.ctrl.a="方法名"image


系统修饰键

  • ctrl、alt、shift、meta(win键)
  • 配合keyup事件使用时,按下修饰键的同时还需按下其他键,随后释放其他键后事件才被触发
  • 配合keydown事件可以正常触发

自动义按键别名

可以使用keyCode去指定具体按键(不推荐)

写法:Vue.config.keyCodes.自定义键名 = 键码


演示案例

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>键盘事件</title>
    <!--引入Vue-->
    <script src="../js/vue.js"></script>
</head>
<body>
    <div id='root'>
        <h2>欢迎{{name}}来此学习</h2>
        <!--
            enter是回车键的别名,代码keyCode值13
            1.Vue中常用的按键别名
                enter(回车)
                delete(删除和退格键)
                esc(退出)
                space(空格)
                tab(换行,必须要配合keydown事件使用)
                up(上)
                down(下)
                left(左)
                right(右)
            2.Vue未提供别名的特殊按键(如CapsLock)可以使用按键名称的去绑定,但注意要转为"小写单词-小写单词"的格式(如caps-lock)
            3.系统修饰键:ctrl、alt、shift、meta(win键)
                配合keyup事件使用时,按下修饰键的同时还需按下其他键,随后释放其他键后事件才被触发
                配合keydown事件可以正常触发
            4.可以使用keyCode去指定具体按键(不推荐)
            5.Vue.config.keyCodes.自定义键名 = 键码,可以自定义按键别名
        -->
        <input type="text" placeholder="按下回车键提示输入" @keyup.enter="showInfo"/>
        <input type="text" placeholder="按下回车键提示输入" @keyup.huiche="showInfo"/>
        <input type="text" placeholder="按下ctrl+A提示输入" @keyup.ctrl.a="showInfo"/>
    </div>
</body>
<script>
    Vue.config.keyCodes.huiche = 13 //自定义回车键的别名
    const vm = new Vue({
        el:'#root',
        data:{
            name:'张三'
        },
        methods:{
            showInfo(e){
                console.log(e.key)//输出按键名称
                console.log(e.keyCode)//输出按键编码
                console.log(e.target.value)//拿到元素中的值
            }
        }
    })
</script>
</html>




七、计算属性与监听属性


计算属性(computed)

介绍

1)定义

本身没有具体值,需要通过已有的属性计算得出

2)原理

底层借助**Objiect.defineProperty()方法提供的getttersetter**

3)get函数何时执行
  • 初次读取时执行一次
  • 当依赖的数据发生改变时会再次调用
4)优势

与methods实现相比,内部有缓存机制(复用),效率更高,调用方便

5)备注
  • 计算属性最终出现在**vm(Vue实例)**上,直接读取使用即可
  • 如果计算属性需要修改必须写set函数响应,且set中要编写修改依赖数据的语句

简写方式

计算属性在computed属性下声明,如果只读不写的情况可以直接使用一个函数完成声明,如下图:

<script>
    const vm = new Vue({
        el:'#root',
        data:{
            xing:'张',
            ming:'三'
        },
        computed:{//计算属性
            /*当此属性只读不改时可以简写成如下格式,相当于
                fullname:{
                    get:function(){
                        return this.xing + '-' + this.ming
                    }
                    // set属性不用写,只用写get
                }
            */
            fullname(){ // 属性名:fullname
                return this.xing + '-' + this.ming
            }
        }
    })
</script>

演示案例

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>姓名案例_计算属性实现</title>
    <!--引入Vue-->
    <script src="../js/vue.js"></script>
</head>
<body>
    <div id='root'>
        姓:<input type="text" v-model:value="xing" /> <br/><br/>
        <!--v-model:value的简写模式v-model-->
        名:<input type="text" v-model="ming" /> <br/><br/>
        全名:<span>{{fullname}}</span>
    </div>
</body>
<script>
    const vm = new Vue({
        el:'#root',
        data:{
            xing:'张',
            ming:'三'
        },
        computed:{//计算属性,计算属性没有实质的值,他的值只能通过getter/setter函数计算得出
            fullname:{
                //当有人读取fullname属性时,get函数会被调用,且返回值作为fullname的值
                //get何时调用?1.初次读取fullName属性时 2.所依赖的数据发送改变时(这里的依赖数据为xing和ming)
                get:function(){
                    return this.xing + '-' + this.ming
                },
                //如果要修改此属性,则调用set函数
                set(value){
                    arr = value.split('-')
                    this.xing = arr[0]
                    this.ming = arr[1]
                }
            }
        }
    })
</script>
</html>

实现效果

GIF 2022-12-12 19-34-50



监视属性(watch)

说明

  • 当被监视的属性发生变化时,回调函数自动被调用

  • 监视的属性必须存在


监视的两种写法

第一种,new Vue时传入watch配置

image

第二种, 通过vm.$watch监视

image


深度监视

Vue中的watch默认不监视对象内部值的改变一层),配置**deep:true可以监视**对象内部值的改变(多层

演示案例
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>天气案例-深度监视</title>
    <!--引入Vue-->
    <script src="../js/vue.js"></script>
</head>
<body>
    <div id='root'>
        <h3>a的值是:{{numbers.a}}</h3>
        <button @click="numbers.a++">点我让a+1</button>
        <h3>b的值是:{{numbers.b}}</h3>
        <button @click="numbers.b++">点我让b+1</button>
    </div>
</body>
<script>
    const vm = new Vue({
        el:'#root',
        data:{
            numbers:{
                a:0,
                b:1,
            },
        },
        watch: {
            //监测多级结构中某个属性的变化
            'numbers.a':{
                handler(){
                    console.log('a被改变了')
                }
            },
            //监视多级结构中所有属性的变化
            numbers:{
                deep:true,//开启深度监视
                handler(){
                    console.log('numbers中有值发生了改变')
                }
            }
        },
    })
</script>
</html>

演示效果

GIF 2022-12-12 19-45-43


监视属性的简写方式

<script>
    const vm = new Vue({
        el:'#root',
        data:{
            isHot:true
        },
        computed: ……,
        methods: ……,
        watch: {
            //正常写法
            /* isHot:{
                //immediate:true,//初始化时就调用handler函数
                //监测isHot属性,当isHot属性被修改时触发
                handler(newValue,oldValue){
                    console.log('isHot被修改了',newValue,oldValue)   
                }
            } */
            //简写
            isHot(newValue,oldValue){
                console.log('isHot被修改了',newValue,oldValue)  
            }
        },
    })
    // 另外一种监听方法
    vm.$watch('isHot',function(newValue,oldValue){
        console.log('isHot被修改了',newValue,oldValue)  
    })

</script>

备注

  • Vue自身可以监视对象内部值改变,但Vue提供的watch默认不可以
  • 使用watch时根据数据的具体结构,决定是否采用深度监视
案例演示
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>天气案例-监听属性</title>
    <!--引入Vue-->
    <script src="../js/vue.js"></script>
</head>
<body>
    <div id='root'>
        <h2>今天天气很{{isHot?'炎热':'凉爽'}}</h2>
        <h2>今天天气很{{info}}</h2>
        <button @click="changeWeather">切换天气</button><br/>
        <!--绑定事件的时候:@xxx="yyy" yyy可以写一些简单的语句,指向vm实例-->
        <button @click="isHot = !isHot">切换天气</button>
    </div>
</body>
<script>
    const vm = new Vue({
        el:'#root',
        data:{
            isHot:true
        },
        computed: {
            info:function(){
                /*相当于
                info:{
                    get:function(){}
                }
                */
                return this.isHot?'炎热':'凉爽'
            }
        },
        methods: {
            changeWeather(){
                this.isHot = !this.isHot
            }
        },
        watch: {//监视属性
            isHot:{//监视isHot属性
                immediate:true,//初始化时就调用handler函数
                //监测isHot属性,当isHot属性被修改时触发
                handler(newValue,oldValue){
                    console.log('isHot被修改了',newValue,oldValue)   
                }
            }
        },
    })
    //在初始化外写监视属性,监视isHot属性
    vm.$watch('isHot',{
                immediate:true,//初始化时就调用handler函数
                //监测isHot属性,当isHot属性被修改时触发
                handler(newValue,oldValue){
                    console.log('isHot被修改了',newValue,oldValue)   
                }
            })
</script>
</html>

演示效果

GIF 2022-12-12 19-52-52



computedwatch之间的区别

区别

  • computed能完成的功能,watch都可以完成
  • watch能完成的功能,computed不一定能完成,例如watch才能进行异步操作

两个重要的小原则

  • 所有Vue管理的函数,最好写成普通函数,这样this指向vm或组件实例对象

  • 所有不被Vue管理的(如定时器回调函数、ajax回调函数)最好写成箭头函数,这样this才指向vm或组件实例对象

案例演示

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>姓名案例_watch写法</title>
    <!--引入Vue-->
    <script src="../js/vue.js"></script>
</head>
<body>
    <div id='root'>
        姓:<input type="text" v-model:value="xing" /> <br/><br/>
        <!--v-model:value的简写模式v-model-->
        名:<input type="text" v-model="ming" /> <br/><br/>
        全名:<span>{{fullName}}</span>
    </div>
</body>
<script>
    const vm = new Vue({
        el:'#root',
        data:{
            xing:'张',
            ming:'三',
            fullName:'张-三'
        },
        watch: {
            xing:{//监视属性的完全写法
                handler:function(newValue,oldValue){
                    //计算属性中不能开启异步数据,但是watch可以开启异步数据
                    setTimeout(() => {
                        this.fullName = newValue + '-' + this.ming
                    }, 1000);
                }
            },
            ming(val){//监视属性的简写方式
                this.fullName = this.xing + '-' + val
            }
        },
    })
</script>
</html>

演示效果

GIF 2022-12-12 19-59-15





八、绑定样式(Class与 Style 绑定)


绑定class样式

  • 写法 :class="xxx"
  • xxx可以是字符串、对象、数组
  • 数组写法适用于要绑定多个样式,个数和名称确定,但不确定用不用
  • 对象写法适用于要绑定多个样式,个数和名称不确定
  • 字符串写法适用于类名不确定,需动态获取

绑定style样式

对象写法

  • :style="{fontSize:xxx}"

  • 其中xxx是动态值

数组写法

  • :tyle="[a,b]"
  • 其中a,b是样式对象

案例演示

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>绑定样式</title>
    <!--引入Vue-->
    <script src="../js/vue.js"></script>
    <style>
        .base{/*基础样式*/
            width: 400px;
            height: 100px;
            padding: 10px;
            border: black 1px solid;
        }
        .happy{/*高兴的背景样式*/
            background-color:tomato;
            border: springgreen 5px solid;
        }
        .sad{/*伤心的背景样式*/
            background-color: blue;
            border: brown 5px solid;
        }
        .normal{/*普通的背景样式*/
            background-color: gray;
            border: blue 5px solid;
        }
        .sjw1{/*字体加粗样式*/
            font-size: 24px;
            font-weight: bold;
        }
        .sjw2{/*字体阴影样式*/
            text-shadow: 0 0 10px black;
        }
        .sjw3{/*边框圆角样式*/
            border-radius: 20px;
        }
    </style>
</head>
<body>
    <div id='root'>
        <!--绑定class样式--字符串写法,适用于样式的类名不确定,需要动态指定-->
        <div class="base" v-bind:class='mood' @click='changeMood'>{{text}}</div><br/><br/>
        <!--`:class`为`v-bind:class`的简写-->
        <!--绑定class样式--数组写法,适用于样式的类名不确定,需动态指定-->
        <div class="base" :class="classArr">{{text}}</div><br/><br/>
        <!--绑定class样式--对象写法,适用于样式个数和名称确定,需动态决定用不用-->
        <div class="base" :class="classObj">{{text}}</div><br/><br/>
        <!--style样式--对象写法-->
        <div class="base" :style="styleObj">{{text}}</div><br/><br/>
        <!--style样式--数组写法(不常用)-->
        <div class="base" :style="styleArr">{{text}}</div><br/><br/>
    </div>
</body>
<script>
    const vm = new Vue({
        el:'#root',
        data:{
            text:'你好,世界!',
            mood:'happy',
            classArr:['sjw1'],//数组写法
            classObj:{//对象写法
                sjw1:false,
                sjw2:false,
                sjw3:true,
            },
            styleObj:{ //style样式--对象写法
                fontSize:'40px',//font-size的键形式
                color:'red',
                backgroundColor:'#0ff',//background-color的键形式
            },
            styleArr:[ //style样式--数组写法
                {backgroundColor:'red',fontSize:'40px'},//对象1
                {borderRadius:'20px',textShadow:'0 0 10px blue'},//对象2
            ],
        },
        methods: {
            changeMood(){
                const arr = ['happy','sad','normal']
                index = Math.floor(Math.random()*3)
                this.mood = arr[index]
            }
        },
    })
    //模拟添加样式
    vm.classArr.shift() //移除最后一个元素 这里移除的是'sjw1'绑定样式.html
    vm.classArr.push('sjw1') //往arr数组中添加一个元素
    vm.classArr.push('sjw2')
    vm.classArr.push('sjw3')
</script>
</html>

演示效果

image





九、条件渲染(v-if、v-show)


v-if

写法

  • v-if="表达式"

  • v-else-if="表达式"

  • v-else=""(简写为v-else)

介绍

适用于:元素切换频率较低的场景

特点:不展示的DOM元素之间被移除

注意:v-if可以和:v-else-if、v-else一起使用,但要求结构不能被“打断”



v-show

写法

  • v-show="表达式"

介绍

适用于:元素切换频率较高的场景

特点:不展示的DOM元素不被移除,仅使用样式隐藏掉

备注

使用v-if时,该DOM元素可能因被移除而无法获取,但使用v-show一定可以获取到。



案例演示

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>条件渲染</title>
    <!--引入Vue-->
    <script src="../js/vue.js"></script>
</head>
<body>
    <div id='root'>
        <!-- 使用v-show做条件渲染(结构存在,只是加了display: none) -->
        <h2 v-show="false">1.欢迎光临,{{name}}</h2>
        <h2 v-show="true">2.欢迎光临,{{name}}</h2>
        <h2 v-show="isShow">3.欢迎光临,{{name}}</h2>
        <!-- 使用v-if做条件渲染 -->
        <h2>当前n的值为:{{n}}</h2>
        <button @click="n++">点我n+1</button>
        <!-- template不影响结构层次,只配合v-if使用,如果使用div的话,<h4>标签外会套一层<div>标签 -->
        <template v-if="n==1"><h4>条件成立,第一条语句得到显示</h4></template>
        <template v-else-if="n==2"><h4>条件成立,第二条语句得到显示</h4></template>
        <template v-else>
            <template v-if="n>=2&&n<=5"><h4>当前n值大于等于2,小于等于5</h4></template>
            <template v-else-if="n>5&&n<11"><h4>当前n值大于5,小于11</h4></template>
            <template v-else><h4>当前的n值等于0或大于10</h4></template>
        </template>
    </div>
</body>
<script>
    const vm = new Vue({
        el:'#root',
        data:{
            name:'张三',
            isShow:true,
            n:0,
        }
    })
</script>
</html>

演示效果

img-n7OHMx8p-1670852076208





十、列表渲染(v-for)


v-for指令

写法

  • v-for="(item, index) in xxx" :key="yyy"

介绍

v-for指令通过循环遍历来展示指定列表的数据,它可以遍历:数组、对象、字符串(不常使用)、指定对象(很少使用)


案例演示

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>基本列表</title>
    <!--引入Vue-->
    <script src="../js/vue.js"></script>
</head>
<body>
    <div id='root'>
        <!--遍历数组-->
        <h2>人员列表(遍历数组)</h2>
        <ul>
            <li v-for="(item,index) in persons" :key="item.id">
                {{index}}:{{item.name}}-{{item.age}}
            </li>
        </ul>
        <!--遍历对象-->
        <h2>汽车信息(遍历对象)</h2>
        <ul>
            <li v-for="(value,key) of cars" :key="key">
                {{key}}:{{value}}
            </li>
        </ul>
    </div>
</body>
<script>
    const vm = new Vue({
        el:'#root',
        data:{
            persons:[
                {id:'001',name:'张三',age:18},
                {id:'002',name:'李四',age:19},
                {id:'003',name:'王五',age:20},
            ],
            cars:{
                name:'奥迪A8',
                price:'70万',
                color:'黑色'
            },
        }
    })
</script>
</html>

演示效果

image



key的原理


虚拟DOM中key的作用

key虚拟DOM对象的标识,当状态中的数据发生改变时,Vue会根据**【新数据】生成【新的虚拟DOM】,随后Vue进行【新虚拟DOM】【旧虚拟DOM】差异比较**


比较规则

旧虚拟DOM中找到与新虚拟DOM相同的key时

  • 第一种情况:若虚拟DOM中内容没有改变,直接使用之前的真实DOM
  • 第二种情况:若虚拟DOM中内容变了,则生成新的真实DOM,随后替换掉页面中之前的真实DOM

旧虚拟DOM中未找到与新虚拟DOM相同的key时,创建新的真实DOM,随后渲染到页面


index作为key可能会引发的问题

  • 第一种情况,若对数据进行逆序添加、逆序删除破坏顺序的操作会产生没有必要真实DOM更新,界面效果没问题,但效率低

  • 第二种情况,如果结构中包含输入类DOM,产生错误的DOM更新,界面出现问题


开发中如何选择key

最好使用每条数据的唯一标识作为key,比如id、手机号、身份证号、学号等唯一标识字段。如不存在对数据的逆序添加、逆序删除等破坏顺序的操作,仅用于渲染列表进行展示,用index作为key没有问题


遍历列表时key的作用

index作为key

在这里插入图片描述

id作为key

在这里插入图片描述

如果v-for是未写key值,Vue会将索引值index自动设置为key值


案例演示

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>key的原理</title>
    <!--引入Vue-->
    <script src="../js/vue.js"></script>
</head>
<body>
    <div id='root'>
        <button @click.once="add">添加一个老刘</button>
        <h2>人员列表(1)</h2>
        <ul>
            <!-- :key指向主键 -->
            <li v-for="(item,index) in persons" :key="index">
                {{item.name}}-{{item.age}}
                <input type="text"/>
            </li>
        </ul>
        <h2>人员列表(2)</h2>
        <ul>
            <!-- :key指向主键 -->
            <li v-for="(item,index) in persons" :key="item.id">
                {{item.name}}-{{item.age}}
                <input type="text"/>
            </li>
        </ul>
    </div>
</body>
<script>
    const vm = new Vue({
        el:'#root',
        data:{
            persons:[
                {id:'001',name:'张三',age:18},
                {id:'002',name:'李四',age:19},
                {id:'003',name:'王五',age:20},
            ],
        },
        methods: {
            add(){
                const p = {id:'004',name:'老刘',age:45}
                this.persons.unshift(p) // 添加到数组第一个
            }
        },})
</script>
</html>

演示效果

img-e8LjMMRY-1670852076210



列表过滤

通过监视属性或计算属性来实现列表的过滤

案例演示

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>列表过滤</title>
    <!--引入Vue-->
    <script src="../js/vue.js"></script>
</head>
<body>
    <div id='root'>
        <h2>人员列表</h2>
        <input type="text" placeholder='请输入名字' v-model="keyWord"/>
        <ul>
            <li v-for="item in filPersons" :key="item.id">
                {{item.name}}-{{item.age}}-{{item.sex}}
            </li>
        </ul>

    </div>
</body>
<script>
    const vm = new Vue({
        el:'#root',
        data:{
            persons:[
                {id:'001',name:'马冬梅',age:18,sex:'女'},
                {id:'002',name:'周杰伦',age:19,sex:'男'},
                {id:'003',name:'周冬雨',age:20,sex:'女'},
                {id:'004',name:'温兆伦',age:21,sex:'男'},
            ],
            //filPersons:[],//收集过滤后的列表信息(监视模式使用)
            keyWord:"",//收集用户的输入 
        },
        watch: { //监视模式过滤列表
            /* keyWord:{
                immediate:true,//初始化时执行一次
                handler(val){
                    this.filPersons =  this.persons.filter((p)=>{ //过滤
                        return p.name.indexOf(val) != -1
                    })
                }
            } */
        },
        computed: { //计算属性过滤列表
            filPersons(){//获得经过过滤后的数组
                return this.persons.filter((p)=>{
                    return p.name.indexOf(this.keyWord) != -1
                })
            }
        },
    })
</script>
</html>

演示效果

GIF 2022-12-12 20-43-05



列表排序

使用计算属性,在过滤列表的基础上进行列表排序

案例演示

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>列表排序</title>
    <!--引入Vue-->
    <script src="../js/vue.js"></script>
</head>
<body>
    <div id='root'>
        <h2>人员列表</h2>
        <input type="text" placeholder='请输入名字' v-model="keyWord"/>
        <button @click="sortType=2">年龄升序</button>
        <button @click="sortType=1">年龄降序</button>
        <button @click="sortType=0">原顺序</button>
        <ul>
            <li v-for="item in filPersons" :key="item.id">
                {{item.name}}-{{item.age}}-{{item.sex}}
            </li>
        </ul>

    </div>
</body>
<script>
    const vm = new Vue({
        el:'#root',
        data:{
            persons:[
                {id:'001',name:'马冬梅',age:38,sex:'女'},
                {id:'002',name:'周杰伦',age:19,sex:'男'},
                {id:'003',name:'周冬雨',age:40,sex:'女'},
                {id:'004',name:'温兆伦',age:21,sex:'男'},
            ],
            keyWord:"",//收集用户的输入 
            sortType:0,// 0 原顺序 1 降序 2升序
        },
        computed: { //计算属性过滤列表
            filPersons(){//获得经过过滤后的数组
                const arr =  this.persons.filter((p)=>{//用来存储待排序的列表
                    return p.name.indexOf(this.keyWord) != -1
                })
                if(this.sortType){//如果排序模式不等于0 开启排序
                    arr.sort((p1,p2)=>{
                        return this.sortType==1 ? p2.age-p1.age : p1.age-p2.age //降序用p2-p1,升序用p1-p2
                    })
                }
                return arr
            }
        },
    })
</script>
</html>

演示效果

初始状态

image

升序

image

降序

image

过滤情况下的降序列表

image





十一、Vue怎么监视数据


Vue会监视data中所有层次的数据


如何监测对象中的数据?

  • 通过setter实现监视,且要在new Vue时就传入要监视的数据

  • 对象中后追加(动态追加)的属性,Vue默认不做响应式处理

  • 如需要给后添加的属性做响应式,可使用如下API

    • Vue.set(目标对象,属性名或下标,值)

    • vm.$set(目标对象,属性名或下标,值)


如何监视数组中的数据?

通过包裹(重写)数组更新元素的方法实现,本质就是做了两件事:

  • 第一是调用原生对应的方法对数组进行更新

  • 第二是重新解析模板,进而更新页面


Vue中修改数组元素使用方法


第一种,使数组的7个变更方法

1)push(追加)

向数组的末尾添加一个或更多元素,并返回新的长度

语法:array.push(item1, item2, ..., itemX)

image


2)pop(删除最后一个元素)

用于删除数组的最后一个元素返回删除的元素

语法:array.pop()

image


3)shift(删除第一个元素)

用于把数组的第一个元素从其中删除,并返回第一个元素的值

语法:array.shift()

image


4)unshift(开头添加)

unshift() 方法可向数组的开头添加一个或更多元素,并返回新的长度

语法:array.unshift(item1,item2, ..., itemX)

在这里插入图片描述


5)splice(删除与添加指定位置的任意个元素)

从数组中添加或删除元素


语法array.splice(index[,howmany][,item1,.....,itemX])

  • index:必需,规定从何处添加/删除元素

    • 该参数是开始插入和(或)删除的数组元素的下标,必须是数字
  • howmany:可选,规定应该删除多少元素

    • 必须是数字,但可以是 “0”

    • 如果未规定此参数,则删除从 index 开始到原数组结尾的所有元素

  • item:可选,要添加到数组的新元素


返回值:如果仅删除一个元素,则返回一个元素的数组。 如果未删除任何元素,则返回空数组

image

实例

img-Y3lbOLAW-1670852076214



6)sort(排序)

排序顺序可以是字母或数字,并按升序或降序。默认排序顺序为按字母升序

语法:array.sort([sortfunction])

  • sortfunction:可选,规定排序顺序。必须是函数

image


7)reverse(反转数组)

reverse() 方法用于颠倒数组中元素的顺序

语法:array.reverse()

image



第二种,使用Vue.set()vm.$set()


注意

Vue.setvm.$set不能给vmvm的根数据对象添加属性!





十二、收集表单数据(表单输入绑定)


根据input类型绑定数据

<input type="text" />(文本框),则v-model收集的是value值,用户输入的就是value

type="radio"(单选框),则v-model收集的是value值,且需要给标签设置value

type="checkbox"(多选框)

  • (1)没有配置inputvalue属性,那么Vue收集的是checked值(勾选or未勾选,是布尔值)

  • (2)配置了inputvalue值时

    • 如果v-model的值是非数组属性,那么收集的还是checked值(布尔值)

    • 如果v-model的值是数组属性,那么收集的是value值组成的数组


v-model的三个修饰符

  • lazy:失去焦点后再收集数据
  • number:输入字符串转换为有效数字
  • trim:过滤输入字符串的首尾空格



案例演示

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>收集表单数据</title>
    <!--引入Vue-->
    <script src="../js/vue.js"></script>
</head>
<body>
    <div id='root'>
        <form @submit.prevent="demo"><!--prevent阻止默认事件刷新页面-->
            <label for="zh">账号:</label><input id="zh" type="text" v-model.trim="userInfo.account" /><br />
            密码:<input type="password" v-model.trim="userInfo.pswd" /><br/>
            年龄:<input type="number" v-model.number="userInfo.age"><br/>
            性别:
            男<input type="radio" name="sex" value="male" v-model="userInfo.sex"><!--需设置默认的value值用于区分男女--><input type="radio" name="sex" value="female" v-model="userInfo.sex"><!--需设置默认的value值用于区分男女-->
            <br/>
            爱好:
            学习<input type="checkbox" value="study" v-model="userInfo.hobby">
            锻炼<input type="checkbox" value="duanlian" v-model="userInfo.hobby">
            写代码<input type="checkbox" value="code" v-model="userInfo.hobby">
            <br/>
            所属校区
            <select v-model='userInfo.ctiy'>
                <option value="">请选择校区</option>
                <option value="beijing">北京</option>
                <option value="shanghai">上海</option>
                <option value="shenzhen">深圳</option>
            </select>
            <br/>
            其他信息:<textarea v-model.lazy='userInfo.other'></textarea><!--lazy脱离焦点后才会收集数据-->
            <br/>
            <input type="checkbox" v-model="userInfo.agree">阅读并接受协议<a href="https://www.baidu.com">《用户协议》</a>
            <br/>
            <button >提交</button>
        </form>
    </div>
</body>
<script>
    const vm = new Vue({
        el:'#root',
        data:{
            userInfo:{
                account:"",
                pswd:"",
                age:"",
                sex:"male",//接受单选框的value值:male或female
                hobby:[],
                ctiy:'',
                other:'',
                agree:false,
            },
        },
        methods: {
            demo(){
                console.log(JSON.stringify(this.userInfo))
            }
        },
    })
</script>
</html>

演示效果

img-Jvk8ZA4i-1670852076215





十三、过滤器


定义

对要显示的数据进行特定格式化后再显示(适用于一些简单处理逻辑)

语法

  • 注册过滤器:Vue.filter(name,callback) new Vue(fulters:{})
  • 使用过滤器: {{xxx | 过滤器名称}} v-bind:属性="xxx | 过滤器名称"

备注

过滤器也可以接受额外参数,多个过滤器可串联;过滤器并不改变原本的数据,是产生新的对应数据


案例演示

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>过滤器</title>
    <!--引入Vue-->
    <script src="../js/vue.js"></script>
    <!--引入dayjs-->
    <script src="../js/dayjs.min.js"></script>
</head>
<body>
    <div id='root'>
        <h2>显示格式化后的时间</h2>
        <!--计算属性实现-->
        <h3>现在是:{{fmtTime}}</h3>
        <!--methods实现-->
        <h3>现在是:{{getFmtTime()}}</h3>
        <!--过滤器实现-->
        <h3>现在是:{{time | timeFormater}}</h3>
        <!--过滤器实现(传参)-->
        <h3>现在是:{{time | timeFormater('YYYY_MM_DD') }}</h3>
        <!--过滤器实现(传参与连接)-->
        <h3>现在是:{{time | timeFormater('YYYY_MM_DD') | mySlice }}</h3>
    </div>
    <div id="root2">
        <h2>{{msg | mySlice}}</h2>
        <!--指令语法v-bind使用过滤器-->
        <h2 :x="msg | mySlice">你好,世界</h2>
    </div>
</body>
<script>
    //全局过滤器
    Vue.filter('mySlice', function(value){
            return value.slice(0,4) + '年' //截取前4位字符
    })
    //vue实例
    const vm = new Vue({
        el:'#root',
        data:{
            time:1644132679607, //时间戳
        },
        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:{ // 局部过滤器
            timeFormater:function(value,format="YYYY年MM月DD日 HH:mm:ss"){
                return dayjs(value).format(format)
            },
        },
    })
    //vue第二个实例
    new Vue({
        el:'#root2',
        data:{
            msg:'hello,world!',
        }
    })
</script>
</html>

演示效果

image

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

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

相关文章

汽车自动驾驶的L0-L5是什么意思?

一、问题 汽车L0、L1、L2、L3、L4、L5自动驾驶都是什么意思呢&#xff1f; 近年来「自动驾驶」对我们来说不再陌生&#xff0c;很多人虽然早有所闻&#xff0c;但是真不懂自动驾驶的L0、L1、L2、L3、L4、L5是什么意思&#xff0c;都有哪些功能&#xff0c;今天就来为大家科普一…

什么蓝牙耳机质量好?公认最好用的蓝牙耳机推荐

现如今&#xff0c;蓝牙耳机在人们的日常使用设备当中扮演着较为重要的角色。无论是听歌、玩游戏、追剧、通话等&#xff0c;都可以通过蓝牙耳机来实现。而蓝牙耳机因为摆脱了线的束缚&#xff0c;日常携带会更便捷。作为一名耳机发烧友&#xff0c;今天来给大家分享几款公认最…

[附源码]Python计算机毕业设计SSM基于大数据的超市进销存预警系统(程序+LW)

项目运行 环境配置&#xff1a; Jdk1.8 Tomcat7.0 Mysql HBuilderX&#xff08;Webstorm也行&#xff09; Eclispe&#xff08;IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&#xff09;。 项目技术&#xff1a; SSM mybatis Maven Vue 等等组成&#xff0c;B/S模式 M…

7 种模型加权集成方法

# 7 种模型加权集成方法 不同任务 -> 不同加权方法 分类 类别投票概率值加权 回归 预测值加权 排序 排序次序加权 目标检测 预测结果NMS 语义分割 像素类别投票加权 集成学习 考虑 模型的多样性 多样性不足 -> 最终预测结果和单个模型类似。 模型的精度差异…

基于MATLAB开发AUTOSAR软件应用层模块-part12.AUTOSAR Dictionary-3 AUTOSAR dictionary界面介绍

本篇我们讲解下AUTOSAR工具箱的Dictionary界面,以及如何使用Dictionary编辑AUTOSAR的元素。 初识界面 打开AUTOSAR Dictionary方式见下图, 点击这个按钮,打开界面, 上图就是AUTOSAR Dictionary的便捷界面 1)AtomicComponnet,是SWC软件组件,一个模型就对应一个

作业-12.12【写注释,QT项目和对象对象树模型】

将QT项目中每个文件的每行代码自行注释一遍 #项目过程管理文件 QT core gui greaterThan(QT_MAJOR_VERSION, 4): QT widgets #所需的类库&#xff0c;超过4版本要加widgets CONFIG c11 #支持c11 # The following define makes your compiler emit warnings if you use…

MySQL 自定义函数一文读懂

MySQL函数 含义&#xff1a;一组预先编译好的SQL语句的集合&#xff0c;理解成批处理语句 1、提高代码的重用性 2、简化操作 3、减少了编译次数并且减少了和数据库服务器的连接次数&#xff0c;提高了效率。 存储过程与函数区别&#xff1a; 存储过程&#xff1a;可以有0个返…

内部群炸锅了,同事又删库了

事件起因 我们的系统中有数据导入的功能&#xff0c;可以把特定的格式的excel数据导入到系统中来 由于客户电脑的文件比较多&#xff0c;很多文件的名字也比较相近&#xff0c;客户在导入excel时选错了文件 这个错误的excel文件的格式恰好能被系统解析&#xff0c;客户也没及…

【专栏】实践篇08| All in docker!动手搭建Redis集群

关注公众号&#xff1a;【离心计划】&#xff0c;一起逃离舒适圈 Redis专栏合集 【专栏】01| Redis夜的第一章 【专栏】基础篇02| Redis 旁路缓存的价值 【专栏】基础篇03| Redis 花样的数据结构 【专栏】基础篇04| Redis 该怎么保证数据不丢失&#xff08;上&#xff09…

(附源码)Spring Boot的网上作业管理系统 毕业设计 612317

基于Spring Boot的网上作业管理系统 摘 要 科技进步的飞速发展引起人们日常生活的巨大变化&#xff0c;电子信息技术的飞速发展使得电子信息技术的各个领域的应用水平得到普及和应用。信息时代的到来已成为不可阻挡的时尚潮流&#xff0c;人类发展的历史正进入一个新时代。在现…

【正点原子FPGA连载】第三十三章OV5640摄像头HDMI显示实验 摘自【正点原子】DFZU2EG/4EV MPSoC 之FPGA开发指南V1.0

1&#xff09;实验平台&#xff1a;正点原子MPSoC开发板 2&#xff09;平台购买地址&#xff1a;https://detail.tmall.com/item.htm?id692450874670 3&#xff09;全套实验源码手册视频下载地址&#xff1a; http://www.openedv.com/thread-340252-1-1.html 第三十三章OV564…

02-Neo4j-CQL

02-Neo4j-CQL&#xff1a; 1、CQL简介 CQL代表Cypher查询语言。 像Oracle数据库具有查询语言SQL&#xff0c;Neo4j具有CQL作为查询语言。 Neo4j CQL 它是Neo4j图形数据库的查询语言。它是一种声明性模式匹配语言它遵循SQL语法。它的语法是非常简单且人性化、可读的格式。 …

具有成本效益的深度信任网络的智能LEACH的多级动态优化(Matlab代码实现)

目录 &#x1f4a5;1 概述 &#x1f4da;2 运行结果 &#x1f389;3 参考文献 &#x1f468;‍&#x1f4bb;4 Matlab代码 &#x1f4a5;1 概述 能量利用率是能量受限无线传感器网络&#xff08;WSN&#xff09;的关键属性&#xff0c;它直接影响网络的寿命。LEACH&#x…

C++入门篇之 注释语法什么写

&#x1f4d2;博客主页&#xff1a; ​​开心档博客主页​​ &#x1f389;欢迎关注&#x1f50e;点赞&#x1f44d;收藏⭐留言&#x1f4dd; &#x1f4cc;本文由开心档原创&#xff01; &#x1f4c6;51CTO首发时间&#xff1a;&#x1f334;2022年12月12日&#x1f334; ✉…

python+requests接口自动化测试框架实例详解教程

前段时间由于公司测试方向的转型&#xff0c;由原来的web页面功能测试转变成接口测试&#xff0c;之前大多都是手工进行&#xff0c;利用postman和jmeter进行的接口测试&#xff0c;后来&#xff0c;组内有人讲原先web自动化的测试框架移驾成接口的自动化框架&#xff0c;使用的…

windows下Qt 5的安装与编译打包

环境与版本 操作系统&#xff1a;windows 10 Qt版本&#xff1a;5.14.2&#xff0c;最后一个有独立安装包的版本&#xff0c;下载地址&#xff1a;archive/qt/5.14/5.14.2 IDE&#xff1a;自带的qt-creator 4.11.1&#xff0c;也可以自行下载其他版本4.14.2&#xff0c;下载…

Mybatis实现增删改查

准备工作&#xff1a;建立项目&#xff0c;连接数据库MySQL&#xff0c;安装Mybatix插件 数据库代码准备&#xff1a; -- 删除tb_brand表 drop table if exists tb_brand; -- 创建tb_brand表 create table tb_brand (-- id 主键id int primary key auto_increment,…

itop3568开发板旋转uboot logo和内核logo

修改设备树 rk_android11.0_sdk/kernel/arch/arm64/boot/dts/rockchip/topeet_rk3568_lcds.dtsi 文件。如果配套的屏幕是 LVDS 7 寸屏幕或者 LVDS10.1 寸 1024*600 屏幕或者 LVDS10.1 寸 1280*800 屏幕&#xff0c;修改如下所示。 &route_lvds{ status "okay"; …

使用Postman+JMeter进行简单的接口测试

以前每次学习接口测试都是百度&#xff0c;查看相关人员的实战经验&#xff0c;没有结合自己公司项目接口真正具体情况。 这里简单分享一下公司项目Web平台的一个查询接口&#xff0c;我会使用2种工具Postman和JMeter如何对同一个接口做调试。 准备工作 首先&#xff0c;登录公…

GATK Germline_SNP_INDEL_2.0 分析遗传病(耳聋)

GATK Germline_SNP_INDEL_2.0 分析遗传病&#xff08;耳聋&#xff09; 一、本文是Gatk Germline spns-indels Pipeline 分析遗传病(耳聋)的升级版&#xff0c;目的是提供开箱即用的分析流程&#xff0c;尽可能简化部署和迁移。 更新内容如下&#xff1a; 人类参考基因组以及…