前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Vue 初体验

Vue 初体验

作者头像
Zkeq
发布2022-05-18 15:40:17
3160
发布2022-05-18 15:40:17
举报
文章被收录于专栏:Zkeq

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

01_Vue3的引入-CDN

1
1
代码语言:javascript
复制
<!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
2
代码语言:javascript
复制
<!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
3
代码语言:javascript
复制
<!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
4
代码语言:javascript
复制
<!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
5
代码语言:javascript
复制
<!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
6
代码语言:javascript
复制
<!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>
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022-02-04,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 01_Vue3的引入-CDN
  • 02_Vue3的引入-local
  • 03_计数器案例-原生
  • 04_计数器案例-Vue
  • 05_template写法一
  • 06_template写法二
相关产品与服务
内容分发网络 CDN
内容分发网络(Content Delivery Network,CDN)通过将站点内容发布至遍布全球的海量加速节点,使其用户可就近获取所需内容,避免因网络拥堵、跨运营商、跨地域、跨境等因素带来的网络不稳定、访问延迟高等问题,有效提升下载速度、降低响应时间,提供流畅的用户体验。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档