IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> Vue3-初识-引入-基本操作(第一篇) -> 正文阅读

[JavaScript知识库]Vue3-初识-引入-基本操作(第一篇)

一、Vue3-初识

首先对于vue.js 3.0,它是vue.js 2.0的升级版本,总得来说是对响应式,模板等,更多的是对性能方面的优化,在底层代码和api方面都有更新,而且在vue3中,逐渐使用typeScript语言,更严格!

在这里插入图片描述

1、通过script引入的方式实现vue3应用

vue.global.js

  <script src="../vuejs/vue.global.js"></script>
<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <meta http-equiv="X-UA-Compatible" content="ie=edge" />
    <title>Document</title>
  </head>
  <body>
    <div id="counter">
      <h1>counter:{{ num }}</h1>
    </div>
    <script src="../vuejs/vue.global.js"></script>
    <script>
      const Counter = {
        data: function() {
          return {
            num: 0
          };
        }
      };
       //创建一个应用,将配置的对象counter的内容渲染到选择器
      let app = Vue.createApp(Counter).mount("#counter");
    </script>
  </body>
</html>

在这里插入图片描述

//方式一
 data: function() {
          return {
            num: 0
          };
        }
//方式二
  data1(){
            return{
                num:0
            }
        }
2.vite构建工具创建vue3项目

1.按照步骤输入命令,生成文件目录

//vscode终端输入(终端快捷键ctrl+~)
//创建一个名为vue3demo02文件夹
 npm init vite-app vue3demo02
 //进入文件夹
 cd vue3demo02
 npm install
 npm run dev

按住ctrl点击链接打开项目
在这里插入图片描述

入口文件
在这里插入图片描述在这里插入图片描述

在这里插入图片描述
在这里插入图片描述
示例

<template>
  <div>
  <h1>{{msg}}</h1>
  <button @click="changeMsg">显示内容</button>
  </div>
</template>

<script>
import HelloWorld from './components/HelloWorld.vue'
export default {
  name: 'App',
  data(){
    return{
      msg:999
    }
  },
  methods:{
    changeMsg(){
      this.msg = "你今天有没有喝牛奶"
    }
  }
}
</script>

在这里插入图片描述

二、基本操作
1.Vue声明式语法与数据双向绑定

双向绑定
在这里插入图片描述

在这里插入图片描述###### 4.模板语法常用指令
在这里插入图片描述

在这里插入图片描述
使用 v-html指令

 <!-- v-html指令,使得内容插入html代码 -->
<template>
  <div>
  <h1>{{msg}}</h1>
  <!-- v-once只渲染一次 -->
  <button @click="changeMsg" >显示内容</button>
  <input type="text" v-model="msg">
  <!-- v-html指令,使得内容插入html代码 -->
  <div v-html="content"></div>
  </div>
</template>
<script>
import HelloWorld from './components/HelloWorld.vue'
export default {
  name: 'App',
  data(){
    return{
      msg:999,
      content: `<h1>代码改变事件</h1>`
    }
  },
  methods:{
    changeMsg(){
      this.msg = "你今天有没有喝牛奶"
    }
  }
}
</script>

在这里插入图片描述

<template>
  <div>
  <h1>{{msg}}</h1>
  <!-- v-once只渲染一次 -->
  <button @click="changeMsg" >显示内容</button>
  <input type="text" v-model="msg">
  <!-- v-html指令,使得内容插入html代码 -->
  <div v-html="content"></div>
  <!-- v-bind指令,绑定属性的内容 -->
  <div :id="id" :class="id"></div>
  </div>
</template>

<script>
import HelloWorld from './components/HelloWorld.vue'
export default {
  name: 'App',
  data(){
    return{
      msg:999,
      content: `<h1>代码改变事件</h1>`,
      id:"d1"
    }
  },
  methods:{
    changeMsg(){
      this.msg = "你今天有没有喝牛奶"
      this.id = "d2"
    }
  }
}
</script>
<style>
.d1{
  width: 100px;
  height: 100px;
  background-color: rgb(45, 155, 155);
}
.d2{
  width: 100px;
  height: 100px;
  background-color: blueviolet;
}
</style>

在这里插入图片描述

2.JavaScript表达式在模板中使用
<template>
  <div>
  <!-- JavaScript表达式在模板中使用 -->
  <h1>{{msg.split('')}}</h1>
  <h1>{{msg.split('').reverse()}}</h1>
  <h1>{{msg.split('').reverse().join('')}}</h1>
  <div :id="msg.split('').reverse().join('')"></div>
  <!-- 只能放置一个表达式 -->
  <h1>{{color=="red"?"开心":"难过"}}</h1>
  <button @click="changeMsg">颜色切换</button>
  </div>
</template>

<script>
import HelloWorld from './components/HelloWorld.vue'
export default {
  name: 'App',
  data(){
    return{
      msg:"HelloWorld",
      color:"red"
    }
  },
  methods:{
    changeMsg(){
      this.color = "pink"
    }
  }
}
</script>
<style>
</style>

在这里插入图片描述

3.动态指令(比较少用)
<template>
  <div>
    <div :[attributeName]="id"></div>
    <div></div>
    <button @click="changeMsg">切换颜色</button>
     <button @[eventName]="changeMsg">切换颜色</button>
  </div>
</template>
<script>
import HelloWorld from './components/HelloWorld.vue'
export default {
  name: 'App',
  data(){
    return{
      attributeName:"class",
      id:"d1",
      eventName:"click"
    }
  },
  methods:{
    changeMsg(){
      this.id = "d2"
    }
  }
}
</script>
<style>
.d1{
  width: 100px;
  height: 100px;
  background-color: rgb(45, 155, 155);
}
.d2{
  width: 100px;
  height: 100px;
  background-color: blueviolet;
}
</style>

在这里插入图片描述

4.计算属性

因为在插值表达式中方太多的逻辑对(逻辑:split,join,reverse等方法),不方便

<template>
  <div>
    <div>{{reverseMsg}}</div>
  </div>
</template>
<script>
import HelloWorld from './components/HelloWorld.vue'
export default {
  name: 'App',
  data(){
    return{
      msg:"click"
    }
  },
  computed:{
    reverseMsg:function(){
      return this.msg.split('').reverse().join('')
    }
  },
}
</script>

结果:kcilc

5.watch监听数据的变化
<template>
  <div>
    <input type="text" v-model="msg">
    <h1>{{msg}}</h1>
  </div>
</template>
<script>
import HelloWorld from './components/HelloWorld.vue'
export default {
  name: 'App',
  data(){
    return{
      msg:"click"
    }
  },
  computed:{
    reverseMsg:function(){
      return this.msg.split('').reverse().join('')
    }
  },
  methods:{
  },
  watch:{
    msg:function(newvalue,oldvalue){
      console.log(newvalue)
      console.log(oldvalue)
      if(newvalue.length<3){
        alert("输入内容太短!")
      }
    }
  }
}
</script>

在这里插入图片描述

6.class类名的多种操作方式
<template>
  <div>
    <!-- 第一种写法:直接放置字符串 -->
   <div :class="msg"></div>
   <!--  第二种写法:放置对象-->
   <dir :class="{active:isShow}">hello</dir>
   <!--  第三种写法:放置数组 -->
   <div :class="arry">hello</div>
   <!--  第三种写法:数组和对象结合 -->
   <div :class="[classname,{active:isShow}]"></div>
   <button @click="taggleBtn">taggleBtn</button>
  </div>
</template>
<script>
import HelloWorld from './components/HelloWorld.vue'
export default {
  name: 'App',
  data(){
    return{
    msg:"d1",
    isShow:true,
    arry:['active','d2'],
    classname:'d3'
    }
  },
  methods:{
    taggleBtn:function(){
      this.isShow = ! this.isShow
      this.arry.pop();
    }
  },
}
</script>
<style>
.d1{
  background-color: rgb(255, 176, 19);
  height: 20px;
}
.active{
  background-color: aquamarine;
}
.d2{
  width: 200px;
  height: 20px;
}
.d3{
  margin-top: 15px;
  width:100%;
  height: 20px;
}
</style>

在这里插入图片描述

<template>
  <div>
    <div v-if="user=='vip'">金主爸爸</div>
    <div v-else>金主宝宝</div>
    <h1 v-show="isShow">充值会让你更强大!</h1>
    <!-- //频繁切换用v-show -->
    <button @click="taggleBtn">切换</button>
  </div>
</template>
<script>
import HelloWorld from './components/HelloWorld.vue'
export default {
  name: 'App',
  data(){
    return{
      user:"vip",
      isShow:"true"
    }
  },
  methods:{
    taggleBtn:function(){
      this.isShow = ! this.isShow
    }
  },
}
</script>
7.列表渲染
<template>
  <div>
    <!-- 有序列表 -->
   <ol>
     <li v-for="(item,i) in news" :key="i">{{item}}</li>
   </ol>
  </div>
</template>
<script>
import HelloWorld from './components/HelloWorld.vue'
export default {
  name: 'App',
  data(){
    return{
      user:"vip",
      isShow:"true",
      news:[
        "国内",
        "国外",

      ]
    }
  },
}
</script>

在这里插入图片描述

<template>
  <div>
    <!-- 有序列表 -->
   <ol>
     <li v-for="(item,i) in news" :key="i">{{item.title}}</li>
   </ol>
  </div>
</template>
<script>
import HelloWorld from './components/HelloWorld.vue'
export default {
  name: 'App',
  data(){
    return{
      user:"vip",
      isShow:"true",
      news:[
       {
         title:"直升机坠落",
         tag:"热"
       },
       {
         title:"中秋出现圆月",
         tag:"新"
       }

      ]
    }
  },
  methods:{
    taggleBtn:function(){
      this.isShow = ! this.isShow
     
    }
  },
}
</script>

在这里插入图片描述

<template>
  <div>
    <!-- 有序列表 -->
   <ol>
     <li v-for="(item,i) in table" :key="i">{{item+""+i}}</li>
   </ol>
  </div>
</template>
<script>
import HelloWorld from './components/HelloWorld.vue'
export default {
  name: 'App',
  data(){
    return{
      user:"vip",
      isShow:"true",
      table:{
        name:"coco",
        age:18
      }
    }
  },
  methods:{
    taggleBtn:function(){
      this.isShow = ! this.isShow
     
    }
  },
}
</script>

在这里插入图片描述

8.事件与参数和事件修饰符
<template>
  <div>
    <!-- 直接绑定事件不需要参数 -->
   <h1 @click="addEvent" class="d1">{{num}}</h1>
   <!-- v-on 是全程命令 ,@是缩写的命令-->
   <h1 v-on:click="addEvent" class="d1">{{num}}</h1>
   <h1 v-on:click="num++" class="d1">{{num}}</h1>
   <!-- 一个事件绑定多个处理函数 -->
   <h1 @click="addEvent(),changeColor()" :style="{background:color}">{{num}}</h1> 
   <!-- 事件修饰符
    阻止事件冒泡.stop
    阻止默认事件.prevent
    事件只会触发一次.once
    -->
    <h1 v-on:click.once="addEvent" class="d1">{{num}}</h1>
    <!-- 按键修饰符
    enter/tab/delete/esc/space/up/down/left/right
    系统修饰符
    .ctrl/.alt/.shift/.meta
    鼠标修饰符
    .left/.right/.middle
    -->
    <input type="text" @keydown.enter="searchEvent">
  </div>
</template>
<script>
import HelloWorld from './components/HelloWorld.vue'
export default {
  name: 'App',
  data(){
    return{
      num:0,
      color:"red"
      }
    }
  ,
  methods:{
   addEvent:function(){
     this.num++;
   },
   changeColor:function(){
     this.color = "pink"
   },
   searchEvent:function(){
     console.log("执行了回车搜索事件")
   }
  },
}
</script>
<style>
.d1{
  background-color: aquamarine;
}
</style>

9.表单的数据双向绑定v-model与修饰符

复选框

 <!-- 复选框 -->
   香蕉<input type="checkbox" value="香蕉" v-model="fruits">
      苹果<input type="checkbox" value="苹果" v-model="fruits">
         葡萄<input type="checkbox" value="葡萄" v-model="fruits">
            草莓<input type="checkbox" value="草莓" v-model="fruits">
            <h2>{{fruits}}</h2>

多行文本输入

 <!-- 多行文本输入框 -->
  <textarea name="" id="" cols="30" rows="10" v-model="cheack"></textarea>
   <h1>{{cheack}}</h1>

单选框

<input type="radio" value="" v-model="sex"><input type="radio" value="" v-model="sex">
    <h2>{{sex}}</h2>

选项框单选

<select name="" id="" v-model="city">
      <option value="上海">上海</option>
      <option value="北京">北京</option>
      <option value="深圳">深圳</option>
      <option value="青岛">青岛</option>
    </select>
    <h2>{{city}}</h2>

选项框多选

    <select name="" id="" v-model="citys" multiple>
      <option value="上海">上海</option>
      <option value="北京">北京</option>
      <option value="深圳">深圳</option>
      <option value="青岛">青岛</option>
    </select>
    <h2>{{citys}}</h2>

表单获取是否选中

  <input type="checkbox" value="" v-model="checked1" true-value="喜欢" false-value="不喜欢" name="like">
   <h2>{{checked1}}</h2>

.lazy、input变为change事件改变值

  <input type="text" v-model.lazy="lazy" >
   <h2>{{lazy}}</h2>

number修饰符转化为数字

   <input type="text" v-model.lazy.number="changenumber">
   <h2>{{changenumber}}</h2>

trim修饰符去掉空格

 <input type="text" v-model.trim="changenumber">
<template>
  <div class="content">
    <!-- 多行文本输入框 -->
   <textarea name="" id="" cols="30" rows="10" v-model="cheack"></textarea>
   <h1>{{cheack}}</h1>
   <!-- 复选框 -->
   香蕉<input type="checkbox" value="香蕉" v-model="fruits">
      苹果<input type="checkbox" value="苹果" v-model="fruits">
         葡萄<input type="checkbox" value="葡萄" v-model="fruits">
            草莓<input type="checkbox" value="草莓" v-model="fruits">
            <h2>{{fruits}}</h2>
    <!-- 单选框 --><input type="radio" value="" v-model="sex"><input type="radio" value="" v-model="sex">
    <h2>{{sex}}</h2>
    <!-- 选项框单选 -->
    <select name="" id="" v-model="city">
      <option value="上海">上海</option>
      <option value="北京">北京</option>
      <option value="深圳">深圳</option>
      <option value="青岛">青岛</option>
    </select>
    <h2>{{city}}</h2>
     <!-- 选项框多选 -->
    <select name="" id="" v-model="citys" multiple>
      <option value="上海">上海</option>
      <option value="北京">北京</option>
      <option value="深圳">深圳</option>
      <option value="青岛">青岛</option>
    </select>
    <h2>{{citys}}</h2>
       <!-- 表单获取是否选中 -->
   <input type="checkbox" value="" v-model="checked1" true-value="喜欢" false-value="不喜欢" name="like">
   <h2>{{checked1}}</h2>
   <!-- .lazy、input变为change事件改变值 -->
   <input type="text" v-model.lazy="lazy" >
   <h2>{{lazy}}</h2>
   <!-- number修饰符转化为数字 -->
   <input type="text" v-model.lazy.number="changenumber">
   <h2>{{changenumber}}</h2>
   <!-- trim修饰符去掉空格 -->
   <input type="text" v-model.trim="changenumber">
  </div>
</template>
<script>
import HelloWorld from './components/HelloWorld.vue'
export default {
  name: 'App',
  data(){
    return{
      cheack:"",
      fruits:[],
      sex:"",
      city:"青岛",
      citys:["青岛"],
      checked1:"喜欢",
      lazy:"",
      changenumber:"1"
      }
    }
  ,
  methods:{
   searchEvent:function(){
     console.log("执行了回车搜索事件")
   },
  },
}
</script>
<style>
textarea{
  resize: none;
  width: 200px;
  height: 50px;
}
</style>

在这里插入图片描述



结束~~
在这里插入图片描述

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2021-12-18 15:53:03  更:2021-12-18 15:53:28 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/8 23:48:07-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码