Skip to main content

Command Palette

Search for a command to run...

Vue 初体验

Published
2 min read
Vue 初体验

点击标题超链接可跳转到对应的html界面

01_Vue3的引入-CDN

1

<!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="app">
        <h2>world</h2>
    </div>
    <script src="https://npm.elemecdn.com/vue@3.0.11/dist/vue.global.js"></script>
    <script>
        const why = {
            template: '<h2>hello</h2>',
        }

        const app = Vue.createApp(why)
        app.mount("#app")
    </script>

</body>
</html>

02_Vue3的引入-local

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="app"></div>

    <script src="../js/vue.js"></script>
    <script>
        Vue.createApp({
            template: '<h2>hello Vue.js! 你好</h2>',
        }).mount("#app")
    </script>

</body>
</html>

03_计数器案例-原生

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>

<h2 class="counter"></h2>
<button class="increment">+1</button>
<button class="decrement">-1</button>


<script>
    // 1.获取所有的元素
    const counterEl = document.querySelector('.counter');
    const incrementEl = document.querySelector('.increment');
    const decrementEl = document.querySelector('.decrement');

    // 2.定义变量
    let counter = 100;
    counterEl.innerText = counter;

    // 3.监听按钮的点击
    incrementEl.addEventListener('click', () => {
        counter++;
        counterEl.innerText = counter;
    });
    decrementEl.addEventListener('click', () => {
        counter--;
        counterEl.innerText = counter;
    });

</script>
</body>
</html>

04_计数器案例-Vue

4

<!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="app"></div>

    <script src="../js/vue.js"></script>
    <script>
        Vue.createApp({
            template: `
            <div>
                <h2>{{message}}</h2>
                <h2>{{counter}}</h2>
                <button @click='increment'>+1</button>
                <button @click='decrement'>-1</button>   
            </div>
            `,                         
            data: function() {
                return {
                    counter: 10 ,
                    message: "hello Vue.js!"
                }
            },
            methods: {
                increment() { //语法糖 写法
                    this.counter++;
                    console.log("increment")
                    console.log(this.counter)
                },
                decrement: function() { //ES5 写法
                    this.counter--;
                    console.log("decrement")
                    console.log(this.counter)
                }
            }
        }).mount("#app")
</script>
</body>
</html>

05_template写法一

5

<!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="app"></div>

    <script type="x-template" id="code">
        <div>
            <h2>{{message}}</h2>
            <h2>{{counter}}</h2>
            <button @click='increment'>+1</button>
            <button @click='decrement'>-1</button>   
        </div>
    </script>

    <script src="../js/vue.js"></script>
    <script>
        Vue.createApp({
            template: '#code', // # 号开头的时候, 就是id. 不是class 会执行 querySelector(#why)
            data: function() {
                return {
                    counter: 100 ,
                    message: "hello Vue.js!"
                }
            },
            methods: {
                increment() { //语法糖 写法
                    this.counter++;
                    console.log("increment")
                    console.log(this.counter)
                },
                decrement: function() { //ES5 写法
                    this.counter--;
                    console.log("decrement")
                    console.log(this.counter)
                }
            }
        }).mount("#app")
</script>
</body>
</html>

06_template写法二

6

<!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="app"></div>

    <template id="code">
        <div>
            <h2>{{message}}</h2>
            <h2>{{counter}}</h2>
            <button @click='increment'>+1</button>
            <button @click='decrement'>-1</button>   
        </div>
    </template>

    <!-- 可以用div 但是会渲染两边. 原始的数据会被保留 -->
    <!-- 也就是 code 里面的内容在解析的时候被显示一次 被 Vue 解析之后, 在 app 中又被渲染一次-->

    <script src="../js/vue.js"></script>
    <script>
        Vue.createApp({
            template: '#code', // # 号开头的时候, 就是id. 不是class 会执行 querySelector(#why)
            data: function() { // vue 2 中 也可以传入一个对象(虽然官方推荐是一个函数) [vue3 中不能传入对象, 否则会报错(只能传函数 返回一个对象)]
                return { 
                    counter: 100 ,
                    message: "hello Vue.js!"
                    // data 中的数据会被 vue 中劫持
                }
            },
            methods: { // 这里不可用箭头函数, 因为箭头函数中的 this 指向的是父组件, 而不是当前组件
                increment() { //语法糖 写法
                    this.counter++;
                    // this 这种就是指向 vue 实例
                    // 可以修改或者获取 , 可以直接访问
                    console.log("increment")
                    console.log(this.counter)
                },
                decrement: function() { //ES5 写法
                    this.counter--;
                    console.log("decrement")
                    console.log(this.counter)
                }
            }
        }).mount("#app")
</script>
</body>
</html>
7 views

More from this blog

MySQL | 表的内连接

数据操作语言:表连接查询(一) 从多张表中提取数据 从多张表提取数据,必须指定关联的条件。如果不定义关联条件就会出现无条件连接,两张表的数据会交叉连接,产生 笛卡尔积。 规定了连接条件的表连接语句,就不会出现笛卡尔积。 # 查询每名员工的部门信息 SELECT e.empno,e.ename,d.dname FROM t_emp e JOIN t_dept d ON e.deptno=d.deptno; 表连接的分类 表连接分为两种:内连接 和 外连接 内连接是结果集中只保留符合...

May 16, 20221 min read13
MySQL | 表的内连接

MySQL | 分组查询的应用

数据操作语言:分组查询 为什么要分组? 默认情况下汇总函数是对全表范围内的数据做统计 GROUP BY 子句的作用是通过一定的规则将一个数据集划分成若干个小的区域,然后针对每个小区域分别进行数据汇总处理 SELECT deptno,AVG(sal) FROM t_emp GROUP BY deptno; SELECT deptno,ROUND(AVG(sal)) FROM t_emp GROUP BY deptno; -- ROUND 取整 逐级分组 数据库支持多列分组条件,执行的时候...

Apr 27, 20221 min read10
MySQL | 分组查询的应用

MySQL | 聚合函数的使用

数据操作语言:聚合函数 什么是聚合函数 聚合函数在数据的查询分析中,应用十分广泛。聚合函数可以对 数据求和、求 最大值 和 最小值 、求 平均值 等等。 求公司员工的评价月收入是多少? SELECT AVG(sal+IFNULL(comm,0)) FROM t_emp; SELECT AVG(sal+IFNULL(comm,0)) AS avg FROM t_emp; SUM 函数 SUM 函数用于求和,只能用户数字类型,字符类型的统计结果为 0 ,日期类型统计结果是毫秒数相加 SE...

Apr 26, 20221 min read8
MySQL | 聚合函数的使用
U

Untitled Publication

173 posts

Vue 初体验