前端Vue基础

2021-02-01  本文已影响0人  放开好人

前言:VSCode使用

插件:
open in browser 右键选择浏览器直接打开页面。
live server 修改文件保存后,页面自动刷新。右键:open with live server
Vue 2 Snippets和VueHelper。vue的代码提示插件,安装其中一个就行。
Vetur 。方便代码编写等。

1. 初始化vue项目

a. 初始化项目:npm init -y 。完成后文件夹会生成package.json,代表npm管理的项目。
b. 安装vue依赖:npm install vue 。安装完成之后文件内会出现node_modules\vue*
c. 引入vue.js

<script src="./node_modules/vue/dist/vue.js"></script>

2. vue简单测试使用

<script src="../node_modules/vue/dist/vue.js"></script>
    <div id="app">
        <input type="text" v-model = "num">
        <button v-on:click="num++">点赞</button>
        <button v-on:click="cancal">取消</button>
        <h1>{{name}},是好人,有{{num}}人这样认为</h1>
    </div>
    <script>
        //1、vue声明式渲染
        let vm = new Vue({
            el:"#app", //绑定元素
            data:{     //封装数据
                name:"fangkk",
                num: 1 //双向绑定
            },
            methods: { //封装方法
                cancal() {
                    this.num--;
                },
            },
        });
        //2、双向绑定,模型变化,视图变化,反之亦然
        //3、事件按钮
        //v-xx:指令
        //1.创建vue实例,关联页面的模板(id=el),将自己的数据(data)渲染到关联的模板,响应式的。
        //2.指令来简化对dom的一些操作。
        //3.声明方法来做更复杂的操作。methods里面可以封装方法。
    </script>

3. 插值表达式和v-html

a. 花括号
格式:{{表达式}}
说明:

b. 插值闪烁
{{表达式}}存在插值闪烁,网速慢的情况下,页面会先展示{{}},后展示完整页面。但目前我测试来讲,未发现,可能已经被优化。
v-html和v-test不会出现插值闪烁。
c. 代码示例

    <script src="../node_modules/vue/dist/vue.js"></script>
    <div id="app">
        {{msg}} 
        {{1+1}}
        {{hello("fangk")}}
        <span v-html="msg"></span>
    </div>
    <script>
        new Vue({
            el: "#app",
            data:{
                msg:"<h1>hello</h1>"
            },
            methods: {
                hello(name) {
                    return "hello "+name;
                },
            },
        });
        //插值表达式:
        //1、表达式必须有返回结果。
        //2、可以直接获取vue实例中定义的数据或函数。
        //3、插值表达式只能写在标签体里面,如果标签属性中需要使用则需v-bind,下节介绍
    </script>

4. v-bind

    <script src="../node_modules/vue/dist/vue.js"></script>
    <div id="app">
        <a href="https://www.baidu.com">跳转1</a>
        <a v-bind:href="link">跳转2</a>
        <span v-bind:class="{active:isActive,'text-danger':hasError}"
        :style="{color:color1,fontSize:size}"
        >你好</span>
    </div>

    <script>
        new Vue({
            el:"#app",
            data:{
                link:"https://www.baidu.com",
                isActive:true,
                hasError:true,
                color1:"blue",
                size:"36px"
            }
        });
        //单项绑定,页面修改不会影响vue中的数据,vue数据修改可以影响页面展示。
        //双向绑定,v-model
    </script>

5. v-model

    <script src="../node_modules/vue/dist/vue.js"></script>
    <!-- 表单项,自定义组件 -->
    <div id = "app">
        精通的语言:</br>
        <input type="checkbox" v-model="language" value="Java">java </br>
        <input type="checkbox" v-model="language" value="PHP">PHP </br>
        <input type="checkbox" v-model="language" value="Python">Python </br>
        <!-- JS提供数组.join()方法,用指定内容连接 -->
        选中了:{{language.join(",")}} 

    </div>

    <script>
        let vm =new Vue({
            el:"#app",
            data:{
                language:[]
            },
            methods:{

            }
        });
    </script>

6.v-on

    <script src="../node_modules/vue/dist/vue.js"></script>
    <div id="app">
        <!-- 事件中直接写js片段 -->
        <button v-on:click="num++">点赞</button>
        <!-- 事件中指定一个回调函数,必须是Vue实例中定义的函数 -->
        <button @click="cancal()">取消</button>

        <h1>有{{num}}个赞</h1>

        <!-- 事件修饰符 -->
        <!-- 
            在事件处理程序中调用‘event.preventDefault()’或event.stopProoagation是非常常见的需求。尽管我们可以在方法中轻松实现这点,
            但更好的方式是:方法只有纯粹的数据逻辑,而不是去处理DOM事件细节。
            为了解决这个问题,Vue.js为v-on提供了事件修饰符。修饰符是由点开头的指令后缀来表示的:
            1.‘.stop’,阻止事件冒泡到父元素。
            2.‘.prevent’,阻止默认事件发生。
            3.‘.capture’,使用事件捕获模式。
            4.‘.self’,只有元素自身触发事件才执行。冒泡或捕获的都不执行。
            5.‘.once’,只执行一次
         -->
        <!-- 小div被点击后,会弹出两次窗口,因为事件冒泡 -->
        <div style="border: 1px solid red;padding:20px" v-on:click="hello()">
            大div
            <div style="border: 1px solid blue;padding:20px" @click.stop="hello()">
                小div </br>
                <a href="http://www.baidu.com" @click.prevent>去百度</a>
            </div>
        </div>

        <!-- 按键修饰符: -->
        <!-- 
            在监听键盘事件时,我们经常需要检查常见的键值。Vue允许为‘v-on’在监听键盘事件时添加按键修饰符:
            例如<input v-on:keyup.13="hello()" > ,只有keyCode是13-enter时调用hello函数
            记住所有的keyCode比较困难,Vue为最常用的按键提供了别名:
            .enter  .tab  .esc .space(空格) .up .down(下键) .left .right 
            .delete(捕获删除和退格键)
         -->
        <input type="text" v-model="num" @keyup.up="num+=2" @keyup.down="num-=2"></br>
        提示:
        <!-- 组合按键 -->
        <input type="text" @keyup.alt.enter="hello()"> </br>
        <input type="text" @click.alt.ctrl="hello()">
    </div>
    <script>
        new Vue({
            el:"#app",
            data:{
                num:1
            },
            methods:{
                cancal(){
                    this.num--;
                },
                hello(){
                    alert("点击了");
                }
            }
        });
    </script>

二、计算属性、侦听器、过滤器

1. 计算属性和侦听器

    <script src="../node_modules/vue/dist/vue.js"></script>
    <div id="app">
        <!-- 某些结果时基于之前数据实时计算出来的,我们可以利用计算属性 -->
        <ul>
            <li>西游记,价格:{{xyjPrice}},数量:<input type="number" v-model="xyjNum"></li>
            <li>水浒传,价格:{{shzPrice}},数量:<input type="number" v-model="shzNum"></li>
            <li>总价:{{totalNum}}</li>
            <li>{{msg}}</li>
        </ul>
    </div>
    <script>
        let ve = new Vue({
            el:"#app",
            data:{
                xyjPrice: 10.00,
                shzPrice: 10.00,
                xyjNum: 1,
                shzNum: 1,
                msg:""
            },
            //计算属性computed
            computed: {
                totalNum(){
                    return this.xyjPrice*this.xyjNum+this.shzPrice*this.shzNum;
                }
            },
            //watch可以让我们监控一个值的变化,从而做出相应的反应。
            watch: {
                xyjNum:function(newValue, oldValue) {
                    if(newValue>=3){
                        this.msg = "库存超出限制";
                        this.xyjNum=3;
                    }else{
                        this.msg="";
                    }
                },
            },

        });
    </script>

2. 局部过滤器和全局过滤器

    <script src="../node_modules/vue/dist/vue.js"></script>
    <div id="app">
        <ul>
            <li v-for="user in userList">
                {{user.id}}==>{{user.name}}==>{{user.gender==1?"男":"女"}}==>{{user.gender | genderFilter}}
                ==>{{user.gender | gFilter}}
            </li>
        </ul>
    </div>
    <script>
        // 全局过滤器
        Vue.filter("gFilter",function(val){
            if(val==1){
                return "男~~~";
            }else{
                return "女~~~";
            }
        })

        let vm = new Vue({
            el:"#app",
            data:{
                userList:[
                    {id:1,name:"fangk",gender:1},
                    {id:2,name:"yuanh",gender:0}
                ]
            },
            //过滤器常用来处理文本格式化的操作,过滤器可以用在两个地方:双花括号插值和v-bind 表达式
            filters:{
                //// filters 定义局部过滤器,只可以在当前vue实例中使用
                genderFilter(gender){
                    if(gender==1){
                        return "男";
                    }else{
                        return "女";
                    }
                }
            }
        });
    </script>

三、组件化

  在大型应用开发的时候,页面可以划分成很多部分。往往不同的页面,也会有相同的部分,例如坑你会有相同的头部导航。
  但是如果每个页面都独自开发,这无疑增加了我们开发的成本。所以我们会把页面的不同部分拆分成独立的组件,然后在不同页面就可以共享这些组件,避免重复开发。
  在vue里,所有的vue实例都是组件。

    <script src="../node_modules/vue/dist/vue.js"></script>
    <div id="app">
        <button v-on:click="count++">我被点击了{{count}}次</button>
        <counter></counter>
        <button-counter></button-counter>
    </div>
    <script>
        //1.全局声明注册一个组件
        Vue.component("counter", {
            template: '<button v-on:click="count++">我被点击了{{count}}次</button>',
            data() {
                return {
                    count: 1
                }
            }
        });
        /*
        1.组件其实也是一个vue实例,因此它在定义时也会接收:data,methods,生命周期函数等。
        2.不同的是组件不会与页面的元素绑定,否则就无法复用了,因此没有el属性。
        3.但是组件渲染需要html模板,所以增加了template属性,值就是HTML模板。
        4.全局组件定义完毕,任何vue实例都可以直接在HTML中通过组件名称来使用组件了。
        5.data必须是一个函数,不再是一个对象
        */
        //2.局部声明一个组件
        const buttonCounter = {
            template: '<button v-on:click="count++">我被点击了{{count}}次~~~</button>',
            data() {
                return {
                    count: 1
                }
            }
        }

        let vm = new Vue({
            el: "#app",
            data: {
                count: 1
            },
            components:{
                'button-counter':buttonCounter
            }
        });
    </script>

四、生命周期钩子函数

  每个vue实例在被创建时都要经过一系列的初始化过程:创建实例,装载模板,渲染模板等等。vue为生命周期中的每个状态都设置了钩子函数(监听函数)。

    <div id="app">
        <span id="num">{{num}}</span>
        <button @click="num++">赞!</button>
        <h2>{{name}},有{{num}}个人点赞</h2>
    </div>

    <script src="../node_modules/vue/dist/vue.js"></script>
    
    <script>
        let app = new Vue({
            el: "#app",
            data: {
                name: "张三",
                num: 100
            },
            methods: {
                show() {
                    return this.name;
                },
                add() {
                    this.num++;
                }
            },
            beforeCreate() {
                console.log("=========beforeCreate=============");
                console.log("数据模型未加载:" + this.name, this.num);
                console.log("方法未加载:" + this.show());
                console.log("html模板未加载:" + document.getElementById("num"));
            },
            created: function () {
                console.log("=========created=============");
                console.log("数据模型已加载:" + this.name, this.num);
                console.log("方法已加载:" + this.show());
                console.log("html模板已加载:" + document.getElementById("num"));
                console.log("html模板未渲染:" + document.getElementById("num").innerText);
            },
            beforeMount() {
                console.log("=========beforeMount=============");
                console.log("html模板未渲染:" + document.getElementById("num").innerText);
            },
            mounted() {
                console.log("=========mounted=============");
                console.log("html模板已渲染:" + document.getElementById("num").innerText);
            },
            beforeUpdate() {
                console.log("=========beforeUpdate=============");
                console.log("数据模型已更新:" + this.num);
                console.log("html模板未更新:" + document.getElementById("num").innerText);
            },
            updated() {
                console.log("=========updated=============");
                console.log("数据模型已更新:" + this.num);
                console.log("html模板已更新:" + document.getElementById("num").innerText);
            }
        });
    </script>
上一篇下一篇

猜你喜欢

热点阅读