国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 編程 > JavaScript > 正文

vue組件初學(xué)_彈射小球(實(shí)例講解)

2019-11-19 15:32:52
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

1. 定義每個(gè)彈射的小球組件( ocicle )

2. 組件message自定義屬性存放小球初始信息(可修改)

{    top: "0px",    //小球距離上方坐標(biāo)   left: "0px",    //小球距離左邊坐標(biāo)   speedX: 12,   //小球每次水平移動(dòng)距離   speedY: 6     //小球每次垂直移動(dòng)距離}  

3. 思路

3.1 定時(shí)器設(shè)置小球每一幀移動(dòng)

3.2 初始方向:isXtrue為true則小球?yàn)闄M坐標(biāo)正方向;

       isYtrue為true則小球?yàn)榭v坐標(biāo)正方向

3.3 每次移動(dòng)之前獲取小球當(dāng)前坐標(biāo)(oleft,otop),當(dāng)前坐標(biāo)加上移動(dòng)距離為下一幀坐標(biāo)

3.4 邊界判斷:橫軸坐標(biāo)范圍超過(guò)最大值則加號(hào)變減號(hào)

4. vue知識(shí)點(diǎn)

4.1 父子組件傳遞信息使用props

4.2 模板編譯之前獲取el寬高

beforeMount: function (){  this.elWidth=this.$el.clientWidth;  this.elHeight=this.$el.clientHeight;}

4.3 子組件獲取el寬高 ( this.$root.elWidth,this.$root.elHeight )

4.4 模板編譯完成后更新子組件信息

mounted: function (){  //根據(jù)父組件信息更新小球數(shù)據(jù)  this.addStyle.top=this.message.top;  this.addStyle.left=this.message.left;  this.speedX=this.message.speedX;  this.speedY=this.message.speedY;  //小球初始坐標(biāo)  this.oleft=parseInt(this.addStyle.left);  this.otop=parseInt(this.addStyle.top);  this.move();}

5. 代碼

<!DOCTYPE html><html lang="en"><head>  <meta charset="UTF-8">  <title>Document</title>  <style>    html,    body{      padding: 0;      margin: 0;      width: 100%;      height: 100%;    }    #app{      width: 800px;      height: 500px;      margin: 50px auto;      outline: 1px solid #f69;      position: relative;    }  </style></head><body>  <div id="app">    <ocicle :message="message1"></ocicle>    <ocicle :message="message2"></ocicle>    <ocicle :message="message3"></ocicle>  </div>    <script src="https://unpkg.com/vue"></script>  <script>    var tem={      props: ["message"],      template: '<div class="article" :style="addStyle"></div>',      data: function (){        return {          //初始化小球樣式          addStyle: {            width: "10px",            height: "10px",            backgroundColor: "#000",            position: "absolute",            marginTop: "-5px",            marginLeft: "-5px",            borderRadius: "50%",            top: "0px",            left: "0px"          },          //橫坐標(biāo)方向的速度          speedX: 0,          //縱坐標(biāo)方向的速度          speedY: 0,          //isX為真,則在橫坐標(biāo)方向?yàn)檎?         isX: true,          //isY為真,則在縱坐標(biāo)方向?yàn)檎?         isY: true,          //小球當(dāng)前坐標(biāo)          oleft: 0,          otop: 0        }      },      mounted: function (){        //根據(jù)父組件信息更新小球數(shù)據(jù)        this.addStyle.top=this.message.top;        this.addStyle.left=this.message.left;        this.speedX=this.message.speedX;        this.speedY=this.message.speedY;        //小球初始坐標(biāo)        this.oleft=parseInt(this.addStyle.left);        this.otop=parseInt(this.addStyle.top);        this.move();      },      methods: {        move: function (){          var self=this;          setInterval(function (){            //更新小球坐標(biāo)            self.oleft=parseInt(self.addStyle.left);            self.otop=parseInt(self.addStyle.top);            self.isXtrue();            self.isYtrue();          }, 20);                    },        //判斷橫坐標(biāo)        isXtrue: function (){          //true 橫坐標(biāo)正方向          //false 橫坐標(biāo)負(fù)方向          if(this.isX){            this.addStyle.left=this.oleft+this.speedX+"px";            //寬度超過(guò)最大邊界            if(this.oleft>this.$root.elWidth-5){              this.addStyle.left=this.oleft-this.speedX+"px";              this.isX=false;            }          }else{            this.addStyle.left=this.oleft-this.speedX+"px";            //寬度超過(guò)最小邊界            if(this.oleft<5){              this.addStyle.left=this.oleft+this.speedX+"px";              this.isX=true;            }          }        },        // 判斷縱坐標(biāo)        isYtrue: function (){          //true 縱坐標(biāo)正方向          //false 縱坐標(biāo)負(fù)方向          if(this.isY){            this.addStyle.top=this.otop+this.speedY+"px";            //高度超過(guò)最大邊界            if(this.otop>this.$root.elHeight-5){              this.addStyle.top=this.otop-this.speedY+"px";              this.isY=false;            }          }else{            this.addStyle.top=this.otop-this.speedY+"px";            //高度超過(guò)最小邊界            if(this.otop<5){              this.addStyle.top=this.otop+this.speedY+"px";              this.isY=true;            }          }        }      }    }    var vm=new Vue({      el: "#app",      data: {        //獲取el節(jié)點(diǎn)寬高        elWidth: 0,        elHeight: 0,        //設(shè)置小球初始信息        message1: {          top: "0px",          left: "600px",          speedX: 12,          speedY: 6        },        message2: {          top: "0px",          left: "300px",          speedX: 8,          speedY: 6        },        message3: {          top: "300px",          left: "0px",          speedX: 13,          speedY: 5        }      },      //更新el節(jié)點(diǎn)寬高      beforeMount: function (){        this.elWidth=this.$el.clientWidth;        this.elHeight=this.$el.clientHeight;      },      components: {        "ocicle": tem      }          })  </script></body></html>

以上這篇vue組件初學(xué)_彈射小球(實(shí)例講解)就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持武林網(wǎng)。

發(fā)表評(píng)論 共有條評(píng)論
用戶(hù)名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 富蕴县| 策勒县| 二连浩特市| 南宁市| 丰顺县| 蒲江县| 灌云县| 湛江市| 雅江县| 阿拉尔市| 融水| 宁武县| 顺平县| 纳雍县| 鱼台县| 信阳市| 河曲县| 儋州市| 长春市| 清水县| 临澧县| 高雄市| 商城县| 东兰县| 顺昌县| 南充市| 简阳市| 潼关县| 荃湾区| 进贤县| 赤水市| 简阳市| 阆中市| 齐齐哈尔市| 城步| 嘉祥县| 宜都市| 长海县| 洪洞县| 五大连池市| 连平县|