1. 程式人生 > >weex入門到掌握

weex入門到掌握

http://localhost:8081/index.android.bundle?platform=android
                                                            1.環境配置
1.下載安裝node 
    檢驗安裝成功:
        node -v
2.在cmd中安裝npm
    檢驗安裝成功:
        npm -v
3.下載git並安裝
    檢驗安裝成功:git -v
4.在cmd中安裝webpack:安裝命令:npm install webpack -g
    檢驗安裝成功:webpack -v

                                                            2.建立weex專案
1.使用命令weex -v先檢查是否安裝了weex 
2.使用命令weex create firstWeexDemo(firstWeexDemo是工程名,自定義)注意的是:在接下來建立工程名時不要出現大寫字母,否則會建立失敗
3.建立完成之後,使用命令 npm install安裝npm解析器
4.安裝完成之後先cd到建立完成的工程目錄在使用命令weex platform add android將建立的工程加入android專案平臺
5.開啟androidStudio->選擇開啟一個已經存在的工程->選擇platform下的andriod目錄匯入
6.匯入完成之後,新增虛擬裝置,create virtual device 建立對應的螢幕尺寸等

                                                            3.weex常用命令和熱更新        
1.先將建立好的工程拉入vscode
2.開啟package.json,進入cmd 先cd到建立的目錄之下,使用命令npm run dev命令執行專案檔案
3.在開啟一個終端,輸入npm run serve,如果配置沒有問題就會自己跳轉到瀏覽器介面
4.weex支援熱更新,所以在src/index.vue中改變,但是頁面並不會隨之改變
5.在開啟一個終端,使用webpack進行打包,打完包之後就可以隨時進行熱更新了 注:如果之前沒有安裝webpack,還需要根據提示安裝webpack-cli腳手架    
        注:每次更改完成之後,都要記得使用webpack打包到dist目錄下(每次會自動打包到dist目錄下),才能實現實時的頁面更新
        但是新增監控之後,只要重新整理介面就會起到更新作用:
        監控設定:在package.json檔案中build改為這種: "build": "webpack --env.NODE_ENV=common",
        
        
        
        
        
                                                            4.Android Studio 開發設定以及weex init建立一個前端使用的weex專案
1.每次啟動之前應該先開啟兩個服務:一個是npm  run build(用於開啟打包的監控服務)
                                        npm run serve(用於在瀏覽器介面執行專案)
2.實時預覽的瀏覽地址:http://192.168.239.1:8082/webpack-dev-server/web/
3.先在vscode中將dist目錄下的index.js的內容copy到androidStudio中的app目錄下的assets下的index.js中(注:如果有兩個index.js,那就全部都copy)
4.更改應用圖示:在androidStudio中,res/mipmap下就存放著圖示
5.打包生成apk檔案,build->Build Bundles/apk->bulid apk
    如果打包成功,就會出現打包成功的提示,如果失敗,就按照提示進行修改
6.weex init 建立的project主要用於前端人員的開發
  weex create 建立的專案主要用於專門開發架構的人員進行開發
7.先切換到建立工程對應的目錄,使用weex init projectName建立一個工程
8.建立完成之後,cd到新建立的工程目錄,在進行npm install
9.把建立的專案使用vscode開啟
10.使用指令 npm run serve開啟對應的專案頁面

                                                            5.weex和vue之間的聯絡
weex與vue之間的不同:
    1.佈局不同:在html或者Vue中我們可以使用浮動佈局,但是weex並不支援,所以請不要使用。
    2.不支援百分數:html中佈局,經常使用百分比進行佈局,這種佈局可以適應不同螢幕,但是你用weex佈局時百分比是不支援的。
    3.不支援綜合寫法:比如html中支援border:1px solid red;但是weex就不支援
    4.weex的畫素只支援px,不支援em rem pt
    
    
    
    
    


                                                            6.自定義元件和Text元件
1.在src目錄下先建立一個vue,裡面用於寫你自定義的內容
    自定義的vue內容:
        <!--html-->
<template>
<!--最外層必須用div包裹-->
    <div class="topHeader">
        <!--文字必須用text包裹-->
        <text class="top_text">你好,weex</text>
    </div>
</template>
<!--js-->
<script>
export default {
    
}
</script>
<!--css-->
<style scoped>
 .topHeader{
     background-color: red;
     padding: 10px;

 }
 .top_text{
     color: #fff;
     font-size: 46px;
     text-align: center;
     lines:1;
 }

</style>
    在顯示的主頁面(index.vue)引用:
        在<script></script>中進行引用:import topHeader from './topHeader.vue';
        在<script></script>中定義一個components,並且進行宣告:
            components:{
    topHeader
  }
    定義完成之後就可以直接在template中定義使用了
    下面講一下text元件:注:只有weex可以使用text元件:        詳情參考此網址:https://weex.apache.org/cn/references/components/text.html
    在css樣式中定義lines屬性:lines=n,那麼引用這個css樣式之後的text中的內容就以n行顯示 注:lines只能在css樣式中定義
    
    
    
    
    
                                                            7.Input元件和初識內建模組
1.注意點一:
    我們在weex中<input />標籤必須寫成閉合形式,如果不閉合在手機或者模擬器中是渲染不出來的,會一直顯示載入。
2.使用init建立的工程打包方式:
    使用命令:npm run build會在dist目錄下生成兩個檔案:生成的兩個檔名字會在最後提示,將index.web.js中的檔案打開復制貼上到androidStudio開啟
    的檔案assets/index.js檔案中(注意是直接複製替換)
下面講一下內建模組:
    在主頁面index.vue的<script>部分宣告對內建模組的定義:
        var modal=weex.requireModule("modal");//引數必須是model
    接下來定義內建模組的宣告週期:
        created(){
    modal.toast({
      message:'頁面初始化成功',//用於提醒的欄位
      duration:3//內建模組持續的秒數
    });
  }
  
  
  
  
  
                                                            8.Image和video元件
1.image元件及其對應的屬性:
    <template></template>內容:
      <!--resize="stretch":重新定義圖片尺寸,其中resize屬性有:stretch預設值,指定圖片按照容器拉伸,有可能使圖片產生形變。
                                                             cover:指定圖片可以被調整到容器,以使圖片完全覆蓋背景區域,圖片有可能被剪裁。
                                                             contain:指定可以不用考慮容器的大小,把影象擴充套件至最大尺寸,以使其寬度和高度完全適應內容區域。
       -->
     <image class="testImage"   resize="cover"
     src=""></image>
    對應的<script></script>內容:無;
    對應的<style></style>內容: 
    .testImage{
    /*
    720px=100%
    1250px=100%
    */
    width:720px;
    height:300px;
  }
    注:image是weex獨有的屬性
2.video元件:
    <template></template>內容:
         <video class="video" :src="src" autoplay controls
      v-on:start="onstart"  v-on:pause="onpause"  v-on:finish="onfinish"  v-on:fail="onfail"></video>
    <script></script>中的內容:
 export default {
  name: 'App',
  data () {
    return {
     src:'https://www.youtube.com/watch?v=wn12uL6pYIc'
    }
  },
  methods:{
      onstart (event) {
        this.state = 'onstart'
      },
      onpause (event) {
        this.state = 'onpause'
      },
      onfinish (event) {
        this.state = 'onfinish'
      },
      onfail (event) {
        this.state = 'onfinish'
      }
  }
    對應的<style></style>樣式:
        .video {
    width: 630px;
    height: 350px;
    margin-top: 60px;
    margin-left: 60px;
  }
所有的程式碼:
    <template>
  <div >
   <text class="text">Hello Word</text>
    <div>
      <input type="text"  placeholder="輸入姓名" class="textInput" :autofocus=true />
       </div>
       <!--resize="stretch":重新定義圖片尺寸,其中resize屬性有:stretch是讓圖片按照容器的尺寸進行拉伸
                                                             cover:以中間為基準進行裁切 
                                                             contain:不用考慮容器尺寸,直接顯示圖片能夠顯示的最大尺寸
       -->
     <image class="testImage"   resize="cover"
     src=""></image>
  
   <video class="video" :src="src" autoplay controls
      v-on:start="onstart"  v-on:pause="onpause"  v-on:finish="onfinish"  v-on:fail="onfail"></video>
  </div>
</template>
<script>
import topHeader from './topHeader.vue';
var modal=weex.requireModule("modal");//引數必須是model
 export default {
  name: 'App',
  data () {
    return {
      logo: 
      '',
     src:'https://www.youtube.com/watch?v=wn12uL6pYIc'
    }
  },
  components:{
    topHeader
  },
  created(){
    modal.toast({
      message:'頁面初始化成功',//用於提醒的欄位
      duration:3//內建模組持續的秒數
    });
  },
  methods:{
      onstart (event) {
        this.state = 'onstart'
      },
      onpause (event) {
        this.state = 'onpause'
      },
      onfinish (event) {
        this.state = 'onfinish'
      },
      onfail (event) {
        this.state = 'onfinish'
      }
  }

}
</script>

<style scoped>
  .wrapper {
    justify-content: center;
    align-items: center;
  }
  .logo {
    width: 424px;
    height: 200px;
  }
  .greeting {
    text-align: center;
    font-size: 50px;
    color: #41B883;
    background: rgb(90, 114, 1)
  }
  .message {
    margin: 30px;
    font-size: 32px;
    color: #727272;
  }
  .text{
  text-align:center;
 
  }
  .textInput{
   
    border-bottom-width:1px; 
  }
  .testImage{
    /*
    720px=100%
    1250px=100%
    */
    width:720px;
    height:300px;
  }
  .video {
    width: 630px;
    height: 350px;
    margin-top: 60px;
    margin-left: 60px;
  }
</style>

                                                            9.製作列表
1.先看一下loadmore元件的功能程式碼:用於上拉載入
    <template>
  <div >
    <!--list相當於html中的ul
           ceil相當於html中的li 
           注:list和ceil都不能進行樣式的編寫
-------------------------------------------------------------------------------------------------------------------
           loadmore:在移動端中上拉載入是經常使用的一個功能,weex中要實現這個功能需要使用一個loadmore屬性,從英文單詞中可以看出,
           就是載入更多的意思。我們在中加入loadmore屬性,並繫結一個fetch方法 
           注:loadmore必須寫在list裡面,要不然就不起作用
           loadmoreoffset:是載入列偏移的意思 
       -->
    <list v-on:loadmore="fetch" loadmoreoffset="10">
      <cell v-for="rum in lists">
         <!--weex要想遍歷陣列,必須使用text,但是text元件應該單獨放在div中-->
         <div class="panel">
           <text class="text">{{rum}}</text>
         </div>
      </cell>
    </list>
  </div>
</template>
<script>
  //宣告一個內聯模組
  var modal=weex.requireModule("modal");//引數必須是model
  export default {
    
    data () {
      return {
        lists:[1,2,3,4,5]
      }
    },
      methods:{
        //fetch(event):用於檢測所有的事件
      fetch(event){
        /*使用內聯模組
        duration:1 1:指的是1秒
        */
        modal.toast({message:'loadmore',duration:1});
        /*用於實現模擬下拉選單的功能
        setTimeout方法解析:包含function delay code
        (注:code 這是一個替代語法,你可以使用字串代替function ,在delay毫秒之後執行字串 
        (使用該語法是不推薦的, 原因和使用 eval()一樣,有安全風險)。)
        function 是你想要在delay毫秒之後執行的函式(function這個單詞不一定要顯示出來,不寫function 直接寫函式體也行)
        延遲的毫秒數 (一秒等於1000毫秒),函式的呼叫會在該延遲之後發生。如果省略該引數,delay取預設值0。實際的延遲時間可能會比 delay 值長
        */
        setTimeout(()=>{
          const length = this.lists.length;
          for(let i=length;i<length+4;i++){
            //給陣列lists不停地新增新元素
            this.lists.push(i+1);
          }
        },800);//此處的800指的是毫秒
      }
    }
  }
  
</script>
<style scoped>
  .panel{
    width:600px;
    height:250px;
    margin-left:75px;
    margin-top:35px;
    margin-bottom:35px;
    flex-direction: column;
    justify-content: center;
    border-width: 2px;
    border-style: solid;
    border-color:rgb(162,217,192);
    background-color:rgba(162, 217, 192, 0.2)
  }
  .text{
    font-size:50px;
    text-align: center;
    color:#41B883;
  }
</style>
2.loading元件的使用:用於下拉載入的元件
    <loading>元件 要使用<loading>元件你需要先去<list>元件上的loadmore和loadmoreoffset屬性,並在list中加入<loading>元件
    程式碼詳情:
        <template>
  <div>
      <list>
        <cell v-for="rum in lists">
          <div class="panel">
            <text class="text">{{rum}}</text>
          </div>
        </cell>
        <!--loading必須寫在list裡面
        display:用於設定顯示loading
        -->
        <loading class="loading" v-on:loading="onloading" :display="showLoading">
          <text class="indicator">Loading...</text>
        </loading>
      </list>
  </div>
</template>
<script>
  //宣告一個內聯模組
  var modal=weex.requireModule("modal");//引數必須是model
  export default {
    
    data () {
      return {
        lists:[1,2,3,4,5]
      }
    },
      methods:{ 
    onloading(event) {
    modal.toast({ message: 'loading', duration: 1 });
    //用於設定loading是否顯示
    this.showLoading = 'show';
      setTimeout(() => {
        const length = this.lists.length;
        for (let i = length; i < length + 4; i++) {
          this.lists.push(i + 1);
        }
        //每次載入完之後就讓loading消失,否則loading就會一直進行
        this.showLoading = 'hide';
      }, 1500)

    }
      }
  }
</script>
<style scoped>
  .panel{
    width:600px;
    height:250px;
    margin-left:75px;
    margin-top:35px;
    margin-bottom:35px;
    flex-direction: column;
    justify-content: center;
    border-width: 2px;
    border-style: solid;
    border-color:rgb(162,217,192);
    background-color:rgba(162, 217, 192, 0.2)
  }
  .text{
    font-size:50px;
    text-align: center;
    color:#41B883;
  }
</style>
3.<refresh>元件
    實際開發中還需要重新整理頁面,weex在列表中也為我們想好了,提供了 <refresh>元件,它的作用就是在上拉時進行重新整理頁面
    <template>
  <div>
    <!--refresh:用於粗略的重新整理監控介面
        pullingdown:能夠細緻的監控介面,能夠返回你下拉了多少畫素
    -->
    <refresh class="refresh" v-on:refresh="onrefresh" v-on:pullingdown="onpullingdown" :display="refreshing">
        <text class="indicator">Refreshing ...</text>
</refresh>
      <list>
        <cell v-for="rum in lists">
          <div class="panel">
            <text class="text">{{rum}}</text>
          </div>
        </cell>
        <!--loading必須寫在list裡面
        display:用於設定顯示loading
        -->
        <loading class="loading" v-on:loading="onloading" :display="showLoading">
          <text class="indicator">Loading...</text>
        </loading>
      </list>
  </div>
</template>
<script>
//宣告一個內聯模組
var modal = weex.requireModule("modal"); //引數必須是model
export default {
  data() {
    return {
      lists: [1, 2, 3, 4, 5],
      showLoading: "hide",
      refreshing: "hide"
    };
  },
  methods: {
    //下拉載入
    onloading(event) {
      modal.toast({ message: "loading", duration: 1 });
      //用於設定loading是否顯示
      this.showLoading = "show";
      setTimeout(() => {
        const length = this.lists.length;
        for (let i = length; i < length + 4; i++) {
          this.lists.push(i + 1);
        }
        //每次載入完之後就讓loading消失,否則loading就會一直進行
        this.showLoading = "hide";
      }, 1500);
    },
    onrefresh(event) {
      modal.toast({ message: "refresh", duration: 1 });
      this.refreshing = "show";
      setTimeout(() => {
        this.lists = [1, 2, 3, 4, 5];
        this.refreshing = "hide";
      }, 2000);
    },
    onpullingdown(event) {
      modal.toast({ message: "pulling down", duration: 1 });
    }
  }
};
</script>
<style scoped>
.panel {
  width: 600px;
  height: 250px;
  margin-left: 75px;
  margin-top: 35px;
  margin-bottom: 35px;
  flex-direction: column;
  justify-content: center;
  border-width: 2px;
  border-style: solid;
  border-color: rgb(162, 217, 192);
  background-color: rgba(162, 217, 192, 0.2);
}
.text {
  font-size: 50px;
  text-align: center;
  color: #41b883;
}
</style>

                                                            10.從後端伺服器上獲取資料
1.stream的引入
要想使用stream,必須使用weex來進行引入。
stream.fetch(options, callback[,progressCallback]):
    options {Object}:請求的一些選項 包含:
                                            method {string}:HTTP 方法 GET 或是 POST
                                            url {string}:請求的 URL
                                            headers {Object}:HTTP 請求頭
                                            type {string}:響應型別, json,text 或是 jsonp {在原生實現中其實與 json 相同)
                                            body {string}:HTTP 請求體。
    注意:
        body 引數僅支援 string 型別的引數,請勿直接傳遞 JSON,必須先將其轉為字串。
        GET 請求不支援 body 方式傳遞引數,請使用 url 傳參。
    callback:回撥函式
        
    測試程式碼:
<template>
  <div>
    <list>
      <cell v-for="news in lists">
        <div class="panel">
          <text class="text">{{news.newsTitle}}</text>
          <text class="content">{{news.newsContent}}</text>
          <text class="content">{{news}}</text>
        </div>
        <div class="panel">
           <text class="title">method = GET</text>
      <text class="count">{{getResult}}</text>
        </div>
      </cell>
    </list>
  </div>
</template>
<script>
const modal = weex.requireModule('modal');
//要想使用stream,必須使用weex來進行引入stream模組。stream主要是用於接收json字串
const stream = weex.requireModule('stream');
export default {
  data() {
    return {
      lists: [],
    }
  },
  /*鉤子函式------在元件例項化完成之後就會執行這個函式,但是頁面還未顯示
  元件例項化之前先請求json資料
  */
  created(){
    let url='http://jsfiddle.net/echo/jsonp/?callback=anything&result=content_in_response';
    //呼叫getNews方法
    this.getNews(url,res=>{
      modal.toast({message:'請求成功',duration:1});
      //把獲取的data資料賦值給lists
      this.lists=res.data;
      console.log("jsonData="+res.data);
    });
  },
  methods: {
    getNews(url,callback){
      //此處是stream的fetch方法
      return stream.fetch({
        //使用get的方式請求
        method:'GET',
        //請求的資料是json格式
        type:'json',
        url:url
        //callback是回撥函式,也就是請求之後呼叫的函式
      },callback);
    }
  }
}
</script>

<style scoped>
.panel {
  width: 650px;
  height: 250px;
  margin-left: 50px;
  margin-top: 35px;
  margin-bottom: 35px;
  flex-direction: column;
  padding-top:15px;
   padding-left:10px;
  padding-right:10px;
  border-width: 2px;
  border-style: solid;
  border-color: rgb(162, 217, 192);
  background-color: rgba(162, 217, 192, 0.2)
}
.text {
  font-size: 36px;
  text-align: center;
  color: #41B883;
}
.content{
  lines:5;
  font-size: 28px;
}
</style>


    詳細的stream使用程式碼:
        <template>
  <scroller>
    <div class="panel">
      <text class="title">method = GET</text>
      <text class="content">{{getResult}}</text>
    </div>
    <div class="panel">
      <text class="title">method = GET / type = jsonp</text>
      <text class="content">{{getJsonpResult}}</text>
    </div>
    <div class="panel">
      <text class="title">method = POST</text>
      <text class="content">{{postResult}}</text>
    </div>
    <div class="panel">
      <text class="title">method = PUT</text>
      <text class="content">{{putResult}}</text>
    </div>
    <div class="panel">
      <text class="title">method = DELETE</text>
      <text class="content">{{deleteResult}}</text>
    </div>
    <div class="panel">
      <text class="title">method = HEAD</text>
      <text class="content">{{headResult}}</text>
    </div>
    <div class="panel">
      <text class="title">method = PATCH</text>
      <text class="content">{{patchResult}}</text>
    </div>
  </scroller>
</template>

<script>
  var stream = weex.requireModule('stream');
  module.exports = {
    data: function () {
      return {
        getJsonpResult: 'loading...',
        getResult: 'loading...',
        postResult: 'loading...',
        putResult: 'loading...',
        deleteResult: 'loading...',
        headResult: 'loading...',
        patchResult: 'loading...'
      }
    },
    created: function() {
      var me = this;
      var GET_URL_JSONP = 'http://jsfiddle.net/echo/jsonp/?callback=anything&result=content_in_response';
      var GET_URL = 'http://httpbin.org/get';
      var POST_URL = 'http://httpbin.org/post';
      var PUT_URL = 'http://httpbin.org/put';
      var DELETE_URL = 'http://httpbin.org/delete';
      var HEAD_URL = 'http://httpbin.org/status/418';
      var PATCH_URL = 'http://httpbin.org/patch';

      stream.fetch({
        method: 'GET',
        url: GET_URL_JSONP,
        type:'jsonp'
      }, function(ret) {
        if(!ret.ok){
          me.getJsonpResult = "request failed";
        }else{
          console.log('get:'+ret);
          me.getJsonpResult =  JSON.stringify(ret.data);
        }
      },function(response){
        console.log('get jsonp in progress:'+response.length);
        me.getJsonpResult = "bytes received:"+response.length;
      });

      stream.fetch({
        method: 'GET',
        url: GET_URL,
        type:'json'
      }, function(ret) {
        if(!ret.ok){
          me.getResult = "request failed";
        }else{
          console.log('get:'+ret);
          me.getResult = JSON.stringify(ret.data);
        }
      },function(response){
        console.log('get in progress:'+response.length);
        me.getResult = "bytes received:"+response.length;
      });

      stream.fetch({
        method: 'POST',
        url: POST_URL,
        type:'json'
      }, function(ret) {
        if(!ret.ok){
          me.postResult = "request failed";
        }else{
          console.log('get:'+JSON.stringify(ret));
          me.postResult = JSON.stringify(ret.data);
        }
      },function(response){
        console.log('get in progress:'+response.length);
        me.postResult = "bytes received:"+response.length;
      });

      stream.fetch({
        method: 'PUT',
        url: PUT_URL,
        type:'json'
      }, function(ret) {
        if(!ret.ok){
          me.putResult = "request failed";
        }else{
          console.log('get:'+JSON.stringify(ret));
          me.putResult = JSON.stringify(ret.data);
        }
      },function(response){
        console.log('get in progress:'+response.length);
        me.putResult = "bytes received:"+response.length;
      });

      stream.fetch({
        method: 'DELETE',
        url: DELETE_URL,
        type:'json'
      }, function(ret) {

        if(!ret.ok){
          me.deleteResult = "request failed";
        }else{
          console.log('get:'+JSON.stringify(ret));
          me.deleteResult = JSON.stringify(ret.data);
        }
      },function(response){
        console.log('get in progress:'+response.length);
        me.deleteResult = "bytes received:"+response.length;
      });

      stream.fetch({
        method: 'HEAD',
        url: HEAD_URL,
        type:'json'
      }, function(ret) {
        if(ret.statusText !== 'I\'m a teapot'){
          me.headResult = "request failed";
        }else{
          console.log('get:'+JSON.stringify(ret));
          me.headResult = ret.statusText;
        }
      },function(response){
        console.log('get in progress:'+response.length);
        me.headResult = "bytes received:"+response.length;
      });

      stream.fetch({
        method: 'PATCH',
        url: PATCH_URL,
        type:'json'
      }, function(ret) {
        if(!ret.ok){
          me.patchResult = "request failed";
        }else{
          console.log('get:'+JSON.stringify(ret));
          me.patchResult = JSON.stringify(ret.data);
        }
      },function(response){
        console.log('get in progress:'+response.length);
        me.patchResult = "bytes received:"+response.length;
      });
    }
  };
</script>

<style scoped>
.panel {
  width: 650px;
  height: 250px;
  margin-left: 50px;
  margin-top: 35px;
  margin-bottom: 35px;
  flex-direction: column;
  padding-top:15px;
   padding-left:10px;
  padding-right:10px;
  border-width: 2px;
  border-style: solid;
  border-color: rgb(162, 217, 192);
  background-color: rgba(162, 217, 192, 0.2)
}
.text {
  font-size: 36px;
  text-align: center;
  color: #41B883;
}
.content{
  lines:5;
  font-size: 28px;
}
</style>

                                                            11.作輪播圖片效果
<template>
  <div>
      <!--
      slider:是實現輪滑的元件,這個是weex的內建元件
      interval:以毫秒為單位,表示多久更換一次圖片 但是要想使用自動輪播,必須配合另一個屬性auto-play
    auto-play是自動播放,設定為true就可以實現自動播放
    infinite:用於迴圈播放,預設值為true
    indicator:是slider的子元件,用於顯示書籤效果 必須充當 元件的子元件使用
    -->
    <slider class="slider" interval="3000" auto-play="true" infinite="true">
      <div class="frame" v-for="img in imageList">
        <image class="image" resize="cover" :src="img.src"></image>
      </div>
      <!--由於indicator是slider的子元件,絕對不允許寫在div中-->
      <indicator class="indicator"></indicator>
    </slider>
  </div>
</template>

<script>
  export default {
    data () {
      return {
        imageList: [
          { src: 'https://gd2.alicdn.com/bao/uploaded/i2/T14H1LFwBcXXXXXXXX_!!0-item_pic.jpg'},
          { src: 'https://gd1.alicdn.com/bao/uploaded/i1/TB1PXJCJFXXXXciXFXXXXXXXXXX_!!0-item_pic.jpg'},
          { src: 'https://gd3.alicdn.com/bao/uploaded/i3/TB1x6hYLXXXXXazXVXXXXXXXXXX_!!0-item_pic.jpg'}
        ]
      }
    }
  }
</script>

<style scoped>
  .image {
    width: 700px;
    height: 700px;
  }
  .slider {
    margin-top: 25px;
    margin-left: 25px;
    width: 700px;
    height: 700px;
    border-width: 2px;
    border-style: solid;
    border-color: #41B883;
  }
  .frame {
    width: 700px;
    height: 700px;
    position: relative;
  }
  .indicator{
    height:700px ;
    width:700px ;
    /*
     item-color:是indicator獨有的樣式,它是用於定義書籤圓點的顏色
     item-selected-color:是indicator獨有的樣式,它是用於設定被選中時的顏色
    */
    item-color:#ffff;
     item-selected-color:red;
     /*
     此處的設定是用於設定真實的執行時圓點標籤的產生效果
     */
     position: absolute;
  }
</style>

                                                            12.a元件和web元件
使用<a>元件時需要和我們html中的<a>標籤區分,html中的<a>標籤是用來連結html頁面的,而weex中的<a>元件是用來連結weex格式的js檔案的
判斷是否可以訪問到你所建立的檔案:
    先cd到建立的目錄之下,使用命令ipconfig檢視ipv4的地址
    比如我的是192.168.239.1
    後面新增埠號8080或者8081等。
    訪問地址http://192.168.239.1:8081/slider.js(slider.js就是你要判斷是否可以訪問的檔案)
    如果可以訪問那麼就會顯示這個檔案裡面的內容,如果未顯示,說明不能進行訪問
    index.vue中的主要程式碼如下:
        <template>
  <div class="wrapper">
    <!--href如果是要訪問連線,必須把地址路徑寫完整-->
    <a class="button" href="http://192.168.239.1:8081/slider.js">
    <text class="text">跳轉輪播圖</text>
    </a>
  </div>
</template>
下面講一下web元件    在原生的軟體中嵌入網站頁面
<template>
  <div class="wrapper">
    <!--直接引用web元件,在原生的軟體中嵌入網站頁面
   pagestart:<web>元件開始載入時此事件觸發。
   pagefinish:<web>元件完成載入時此事件觸發。
   error:如果<web>元件出現錯誤,會發送此事件訊息。
    -->
  <web src="https://www.baidu.com/" class="web" v-on:pagestart="start" v-on:pagefinish="finish" v-on:error="error"></web>
  </div>
</template>
<script>
/*使用宣告週期----鉤子函式
先定義一個modal
*/
const modal = weex.requireModule("modal");
export default {
  data() {
    return {};
  },
  methods: {
    start() {
      modal.toast({
        message: "頁面開始呼叫", //用於提醒的欄位
        duration: 3 //內建模組持續的秒數
      });
    },
    finish() {
      modal.toast({
        message: "頁面結束呼叫", //用於提醒的欄位
        duration: 3 //內建模組持續的秒數
      });
    },
    error() {
      modal.toast({
        message: "頁面呼叫錯誤", //用於提醒的欄位
        duration: 3 //內建模組持續的秒數
      });
    }
  }
};
</script>
<style scoped>
.wrapper {
  flex-direction: column;
  justify-content: center;
}
.web {
  margin-left: 75px;
  width: 600px;
  height: 750px;
  border-width: 2px;
  border-style: solid;
  border-color: #41b883;
}
</style>

                                                            13.通用事件和動畫模組
1.先描述一些常見的事件:
    <1>longpress(長按事件):如果一個元件被綁定了 longpress 事件,那麼當用戶長按這個元件時,該事件將會被觸發。
    <2>Appear(螢幕內事件):如果一個位於某個可滾動區域內的元件被綁定了 appear 事件,那麼當這個元件的狀態變為在螢幕上可見時,
        該事件將被觸發。
    <3>Disappear(螢幕外事件):如果一個位於某個可滾動區域內的元件被綁定了 disappear 事件,
        那麼當這個元件被滑出螢幕變為不可見狀態時,該事件將被觸發。
2.動畫效果:
    <template>
  <div class="wrapper">
    <!--ref:ref 被用來給元素或子元件註冊引用資訊,引用資訊將會註冊在父元件的 $refs 物件上。
    如果在普通的 DOM 元素上使用,引用指向的就是DOM 元素;如果用在子元件上,引用就指向元件例項。-->
    <div ref="test" v-on:click="move" class="box"></div>
  </div>
</template>

<script>
  const modal = weex.requireModule('modal');
  //引入動畫模組
  const animation =weex.requireModule('animation');
  export default {
    data () {
      return {
      }
    },
    methods:{
       move () {
        // 使用$refs屬性可以通過test來引用和操作這個div
        var testEl = this.$refs.test;
        animation.transition(testEl, {
          //styles樣式必須加在引號裡,否則就是無效
          styles: {
            
            color: '#FF0000',
            //過渡方式:讓動畫以何種方式進行過渡,translate(250px, 100px):表示橫軸移動250px,縱軸移動100px;
            transform: 'translate(250px, 100px)',
            //transformOrigin:移動的中心點
            transformOrigin: 'center center'
          },