zoukankan      html  css  js  c++  java
  • vue中mixins的使用方法和注意点---mixins第二篇(异步请求的情况)

    问题tips:当mixins里面包含异步请求函数,而我们又需要在组件中使用该异步请求函数的返回值时,我们会取不到值,如下

    1.mixins中代码

    export const myMixin = {
      data(){
        return {
          num: 1
        }
      },
      methods:{
        function_one(){
          new Promise( (resolve, reject) => {
            let a = 1;
            setTimeout( () => {
              resolve(a)
            }, 500 )
    
          }).then( res => {
            console.log( res , 'res');
            return res
          })
        }
      }
    }

    2.组件中的代码

    <template>
      <div class="app-container">
        <div class="main">
          这是main
        </div>
      </div>
    </template>
    
    <script>
    import { myMixin } from "./mixins/index.js";
    export default {
      mixins:[myMixin],
      mounted(){
        console.log(this.function_one(), 'main_function_one');
    
      }
    }
    </script>
    
    <style scoped>
    .main{
      font-size:28px;
      color:blue;
    }
    </style>

    3.打印台输出

    总结:this.function_one()为undefine

    解决方法:不要返回结果而是直接返回异步函数,在组件中调用异步函数,异步函数的then回调函数里面做数据处理

    1.mixins中代码

    export const myMixin = {
      data(){
        return {
          num: 1
        }
      },
      methods:{
        async function_one(){
          let result = new Promise( (resolve, reject) => {
            let a = 1;
            setTimeout( () => {
              resolve(a)
            }, 500 )
          })
          return result
        }
      }
    }

    2.组件中的代码

    <template>
      <div class="app-container">
        <div class="main">
          这是main
        </div>
      </div>
    </template>
    
    <script>
    import { myMixin } from "./mixins/index.js";
    export default {
      mixins:[myMixin],
      mounted(){
        this.function_one().then( res => {
          console.log(res, 'main_function_one');
        } )
    
    
      }
    }
    </script>
    
    <style scoped>
    .main{
      font-size:28px;
      color:blue;
    }
    </style>

    3.打印台输出

    参考---https://www.cnblogs.com/Ivy-s/p/10022636.html

  • 相关阅读:
    信用卡:银联,VISA,MasterCard
    Syncthing vs BitTorrent Sync
    语言代码
    ATMEL精妙的IRQ中断处理过程
    CAN 总线通信控制芯片SJA1000 的读写
    ARM ® and Thumb ®-2 指令系统
    DeJaVu update history
    74系列的型号
    2007 Audi A4 INSTRUMENT CLUSTER WIRING DIAGRAM
    0-10岁儿童体重、身高参考值
  • 原文地址:https://www.cnblogs.com/pwindy/p/14763701.html
Copyright © 2011-2022 走看看