zoukankan      html  css  js  c++  java
  • vue使用(二)

    本节目标:

              1.数据路径的三种方式
              2.{{}}和v-html的区别

    1.绑定图片的路径

    方法一:直接写路径

    <img src="http://pic.baike.soso.com/p/20140109/20140109142534-188809525.jpg">

    方法二:在data中写路径,在div中使用

    <img v-bind:src="url">

    然后在data中写路径

      data () {
        return {
            msg:'你好,我是啦啦啦!',
            url:'http://pic.baike.soso.com/p/20140109/20140109142534-188809525.jpg',
        }
      }

    方法三:这个和方法二一样,变化的为红色标注部分

       <img :src="url">

    2。使用{{}}和使用v-html的区别

    使用{{}}的时候数据会原样输出,使用v-html的使用会将特殊字符进行解析成html,然后显示。

    这种方式是将他们的数据直接输出,并没有达到我们想要的解析
        {{h}}
         <hr/>
           下面的方法可以解决问题
         <div v-html="h"></div>

    3.绑定数据的第二种方法

     绑定数据的第二种方法是
     <div v-text="msg"> </div>

    4.绑定样式

    <hr/>
        绑定样式的使用
            <div v-bind:class="{'red':flag}">
       我是渣渣!
            </div>

    也可以写成简单的形式,将v-bind:直接写成:

    5.方法的调用

     (1)无参数的调用

    <button v-on:click="getmsg()">我是按钮!</button>
    

    对于这个注意下面的写法

    methods:{
          getmsg(){
              /*alert('方法执行!');*/
            alert(this.msg);
          }

    方法调用写在methods中。

     (2) 有参数方法的调用

    <button @click="fun04('1111')">
    fun04(val)
    {
        alert(val);
    }

    6.动态值的绑定,就是数据只要发生变化,使用此变量值的地方都会发生变化。

    {{msg}}只要数据发生改变,这里的值也会发生改变
    <button v-on:click="setmsg()">我是改变</button>

    methods的写法

    setmsg(){
              /*alert('方法执行!');*/
            this.msg="我是渣渣!"
          }

    7.ref获取值,并显示

    <input type="text" ref="info"/>

    获取值

    this.$refs.info

    显示值(这个使用到了上面的动态值绑定,只要值发生改变,启用的地方就会发生变化)

    <div ref="box">我是;啦啦啦</div>
    
    this.$refs.box.style.background='this.$refs.info.value';

    设置背景色

    this.$refs.box.style.background='red';

    8.历史值的获取

    我们有时候在页面上显示数据的时候,当我们刷新之后,数据就会消失,所以我们可以使用声明周期函数,将数据加入到声明周期中进行保存,在刷新之后,可以重新的显示数据

    数据
    data () {
    return { todo:'dsfh', list:[], ok:true } }
    methods:{
          doAdd(){
              this.list.push(this.todo);
              localStorage.setItem('list',JSON.stringify(this.list));
          },deelete(val){
              //在某个位置上删除数据
              this.list.splice(val,1);
              localStorage.setItem('list',JSON.stringify(this.list)) 
              /*this.list.pop(val);*/
            /*上面的两个方法是相同的 */
          }
      }

    红色的是将值保存起来,当我们刷新出发声明周期方法,

    mounted()
          {
              
              var list = JSON.parse(localStorage.getItem('list'));
              alert(list);
              if(list)
              {
    this.list = list;将数据设置回list中去
              }
          }

    9.组件的使用

    (1)创建一个组件

    <template>
        <!--所有的内容需要被div包含起来-->
        <div id="home">
            <h2>这是一个组件</h2>
            {{msg}}
        </div>
    </template>
    <!--在组件中也是可以放入业务逻辑的-->
    <script>
    export default{
        data(){
            return{
                msg:'我是啦啦啦!'    
            }        
        }
    }
    </script>
    <!--scoped表示局部作用域 -->
    <style lang="scss" scoped>
    </style>

    (2)将组件引入

    import Home from './component/Home.vue';

    (3)将组件挂载

     components:{
          /**
           * 2.挂载组件
           */
          'v-home':Home,
          'v-news':News
      }

    (4)使用组件

    <v-home></v-home>

    10,生命周期函数

    这个比较简单


             

  • 相关阅读:
    猜数字和楼层扔鸡蛋问题
    python+selenium+unittest----skip(跳过用例)
    python+selenium+unittest----常用属性详解(框架属性详解)
    php----等比缩放图片
    Vue----生命周期
    js----定义变量的几种方式
    quartz(7)-源码分析
    quartz(6)--集群
    quartz(5)--作业管理和存储
    quartz(4)--quartz.properties文件
  • 原文地址:https://www.cnblogs.com/kw28188151/p/9195346.html
Copyright © 2011-2022 走看看