欧美一区二区三区老妇人-欧美做爰猛烈大尺度电-99久久夜色精品国产亚洲a-亚洲福利视频一区二区

Vue如何實現(xiàn)頁面狀態(tài)保持頁面間數(shù)據(jù)傳輸

這篇文章主要為大家展示了“Vue如何實現(xiàn)頁面狀態(tài)保持頁面間數(shù)據(jù)傳輸”,內(nèi)容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領(lǐng)大家一起研究并學(xué)習(xí)一下“Vue如何實現(xiàn)頁面狀態(tài)保持頁面間數(shù)據(jù)傳輸”這篇文章吧。

成都創(chuàng)新互聯(lián)主要從事網(wǎng)站設(shè)計、做網(wǎng)站、網(wǎng)頁設(shè)計、企業(yè)做網(wǎng)站、公司建網(wǎng)站等業(yè)務(wù)。立足成都服務(wù)東風(fēng),10余年網(wǎng)站建設(shè)經(jīng)驗,價格優(yōu)惠、服務(wù)專業(yè),歡迎來電咨詢建站服務(wù):18980820575

vue router給我們提供了兩種頁面間傳遞參數(shù)的方式:

  • 動態(tài)路由匹配

  • 編程式的導(dǎo)航

// 命名的路由
router.push({ name: 'user', params: { userId: 123 }})

// 帶查詢參數(shù),變成 /register?plan=private
router.push({ path: 'register', query: { plan: 'private' }})

下面介紹一下 vue-viewplus 一個簡化Vue應(yīng)用開發(fā)的工具庫 中的參數(shù)棧模塊params-stack.js:

該插件為Vue實例提供了一個 $vp 屬性,模塊提供了一系列api,來做自己的頁面參數(shù)方式:

// 跳轉(zhuǎn)頁面,并傳遞參數(shù)
this.$vp.psPageNext('/Demo/PageStack/Page2', {
 params: {
  phoneNumb: '15111111111'
 }
})

這一點和vue router給我們提供的傳遞方式類似,并且目前還不支持 query: { plan: 'private' } 傳遞url參數(shù),但是我們?yōu)槭裁催€要做這個模塊:

  • 提供一個 棧 來管理棧內(nèi)所有頁面的參數(shù),方便頁面在回退的時候,拿到對應(yīng)頁面的 緩存參數(shù) ;即一般我們使用vue router的時候每個頁面的參數(shù)(除了使用url參數(shù)),在做統(tǒng)一返回鍵處理的時候,都不太方便進(jìn)行頁面狀態(tài)恢復(fù),而如果我們提供了一個棧,在頁面入棧的時候,將當(dāng)前頁面的參數(shù)存儲,在下一個頁面點擊返回按鈕回到當(dāng)前頁面的時候我們再從參數(shù)棧恢復(fù)參數(shù),這樣就能實現(xiàn)客戶端開發(fā)中具有的這一特性;

  • 該參數(shù)棧也支持緩存->自動恢復(fù),vuex state和session storage兩級存儲保證參數(shù)棧不會被頁面刷新而導(dǎo)致頁面參數(shù)丟失

  • 也為了統(tǒng)一編程方式

并且,當(dāng)前模塊提供的參數(shù)傳遞方式,和vue router給我們提供了兩種頁面間傳遞參數(shù)的方式, 并不沖突 ,可以互補使用。

只不過目前插件的參數(shù)棧并沒有管理vue router幫我們傳遞的參數(shù);

vuex state 參數(shù)棧存儲示例:

Vue如何實現(xiàn)頁面狀態(tài)保持頁面間數(shù)據(jù)傳輸

session storage 參數(shù)棧二級存儲示例:

Vue如何實現(xiàn)頁面狀態(tài)保持頁面間數(shù)據(jù)傳輸

示例

模擬一個簡單表單提交流程

Vue如何實現(xiàn)頁面狀態(tài)保持頁面間數(shù)據(jù)傳輸

圖 詳見源碼 example 項目中當(dāng)前模塊示例

表單錄入頁面(簡稱:Page1)

<template>
 <group title="模擬手機號充值 - 堆棧底-第一頁" label-width="5em" class="bottom-group">
  <box gap="10px 10px">
   <x-input title="手機號" v-model="dataParams.phoneNumb"></x-input>
  </box>
  <box gap="10px 10px">
   <x-button plain @click.native="submit()">點擊充值</x-button>
   <x-button plain @click.native="modify()">修改參數(shù)棧內(nèi)參數(shù)對象</x-button>
  </box>
 </group>
</template>

<script type="text/ecmascript-6">
import demoMixin from '../demo-mixin'
import { XInput } from 'vux'
// 1.參數(shù)棧模塊提供的一個**混入**組件,方便頁面組件簡化參數(shù)棧的api操作和開發(fā),詳見下面的`paramsStack mixin`說明
import { paramsStack } from 'vue-viewplus'

export default {
 // 2.使用`paramsStack mixin`
 mixins: [paramsStack, demoMixin],
 components: {
  XInput
 },
 data() {
  return {
   // 3.【可選】`paramsStack mixin`中定義的`data`屬性,聲明當(dāng)前頁面組件是參數(shù)棧的棧底,當(dāng)當(dāng)前頁面被點擊返回彈出的時候,插件會檢測這個屬性,如果為true,就清空參數(shù)棧
   // isStackBottom: true,
   // 4.自定義需要傳遞到下一個頁面的參數(shù)
   dataParams: {
    phoneNumb: ''
   }
  }
 },
 methods: {
  submit() {
   this.$vp.psPageNext('/Demo/PageStack/Page2', {
    params: this.dataParams
   })
  }
 },
 created() {
  // 【可選】類似第三步
  // this.isStackBottom = true
  // 5.解析回傳參數(shù)
  if (!_.isEmpty(this.backParams)) {
   this.dataParams.phoneNumb = this.backParams.phoneNumb
   this.$vp.toast(`通過 backParams.phoneNumb 預(yù)填寫頁面`)
  }
 }
}
</script>

表單確認(rèn)頁面(簡稱:Page2)
<template>
 <group label-width="15em" class="bottom-group">
  <form-preview header-label="請確認(rèn)訂單信息" :body-items="list" ></form-preview>
  <x-input title="請輸出充值金額" v-model="dataParams.amount" ></x-input>
  <box gap="10px 10px">
   <flexbox>
    <flexbox-item>
     <x-button type="default" @click.native="replace()">確認(rèn)</x-button>
    </flexbox-item>
    <flexbox-item>
     <x-button type="default" @click.native="bck()">返回(回傳參數(shù))</x-button>
    </flexbox-item>
   </flexbox>
  </box>
 </group>
</template>

<script type="text/ecmascript-6">
import demoMixin from '../demo-mixin'
import { paramsStack } from 'vue-viewplus'
import { XInput, FormPreview, Flexbox, FlexboxItem } from 'vux'

export default {
 mixins: [paramsStack, demoMixin],
 components: {
  FormPreview,
  Flexbox,
  FlexboxItem,
  XInput
 },
 data() {
  return {
  // 1. 回顯上一個頁面錄入的手機號
   list: [
    {
     label: '手機號',
     value: ''
    }
   ],
   // 2. 自定義需要傳遞到下一個頁面的參數(shù)
   dataParams: {
    phoneNumb: '',
    amount: '50元'
   }
  }
 },
 methods: {
  /**
   * 4.提交表單方式1
   * 如果需要下一個頁面點擊返回,任然要回顯當(dāng)前頁面,就調(diào)用該方法
   * /
  next() {
   this.$vp.psPageNext('/Demo/PageStack/Page4', { params: this.dataParams })
  },
  /**
   * 4.提交表單方式2
   * 一般確認(rèn)頁面都無需被“保留”,故這里使用`this.$vp.psPageReplace`接口完成跳轉(zhuǎn),底層將會使用
   * `router.replace({location})`完成跳轉(zhuǎn)
   */
  replace() {
   this.$vp.psPageReplace('/Demo/PageStack/Page4', {params: this.dataParams})
  },
  bck() {
   this.$vp.psPageGoBack({
    // 3.設(shè)置回傳參數(shù)
    backParams: {
     phoneNumb: '13222222222'
    }
   })
  }
 },
 created() {
  this.list[0].value = this.params.phoneNumb
  this.dataParams.phoneNumb = this.params.phoneNumb
 }
}
</script>

表單結(jié)果頁面(簡稱:Page4)
<template>
 <div>
  <msg title="操作成功" :description="description" :buttons="buttons"></msg>
 </div>

</template>

<script type="text/ecmascript-6">
 import demoMixin from '../demo-mixin'
 import { paramsStack } from 'vue-viewplus'
 import { FormPreview, Msg } from 'vux'

 export default {
  mixins: [paramsStack, demoMixin],
  components: {
   FormPreview,
   Msg
  },
  data() {
   return {
    description: '',
    buttons: [{
     type: 'primary',
     text: '在做一筆',
     onClick: ((that) => {
      return () => {
       // 返回棧頂頁面
       that.$vp.psPageGoBack()
      }
     })(this)
    }, {
     type: 'default',
     text: '完成',
     onClick: ((that) => {
      return () => {
       // 返回指定頁面,并清空參數(shù)棧
       // that.$vp.psPageGoBack({
       //  backPopPageNumbs: -2,
       //  clearParamsStack: true
       // })
       that.$vp.psPageNext('/Demo', {
        clearParamsStack: true,
        backState: true
       })
      }
     })(this)
    }]
   }
  },
  created() {
   this.description = `${this.params.phoneNumb} 成功充值 ${this.params.amount}`
  }
 }
</script>

paramsStack mixin

以上3個頁面都集成了 paramsStack mixin ,定義如下:

/**
 * 參數(shù)棧mixin對象
 * <p>
 *  方便頁面組件繼承之后操作參數(shù)棧
 * @type {Object}
 */
export const paramsStackMixin = {
 data() {
  return {
   /**
    * 聲明該頁面是棧底部
    */
   isStackBottom: false
  }
 },
 computed: {
  ...mapGetters([
   /**
    * 查看`vuex#vplus.paramsStack[top-length]`棧頂參數(shù)
    */
   'params'
  ]),
  /**
   * 查看`vuex#vplus.backParams`回傳參數(shù)
   */
  backParams() {
   return this.$store.state[MODULE_NAME].backParams
  },
  /**
   * 查看`vuex#vplus.backState`是否是出棧|是否是返回狀態(tài)
   */
  backState() {
   return this.$store.state[MODULE_NAME].backState
  }
 },
 methods: {
  ...mapMutations([
   /**
    * 入棧
    */
   'pushParams',
   /**
    * 修改棧頂參數(shù)
    */
   'modifyParams',
   /**
    * 出棧
    */
   'popParams',
   /**
    * 清空參數(shù)棧
    */
   'clearParamsStack',
   /**
    * 設(shè)置是否是出棧|是否是返回狀態(tài)(點擊返回頁面)
    */
   'setBackState'
  ])
 },
 // 導(dǎo)航離開該組件的對應(yīng)路由時調(diào)用
 beforeRouteLeave(to, from, next) {
  if (this.backState && this.isStackBottom) {
   this.clearParamsStack()
  }
  next()
 }
}

配置

沒有個性化配置,可以查看全局通用配置

API接口

restoreParamsStack

/**
  * $vp.restoreParamsStack()
  * 恢復(fù)插件中`vuex#$vp.paramsStack` && vuex#$vp.backParams` && vuex#$vp.backState`參數(shù)棧所用狀態(tài)
  * <p>
  * 在當(dāng)前模塊重新安裝的時候,一般對應(yīng)就是插件初始化和頁面刷新的時候
  */
 restoreParamsStack()

psModifyBackState

/**
  * $vp.psModifyBackState(bckState)
  * <p>
  * 設(shè)置`vuex#vplus.backState`返回狀態(tài)
  * @param {Boolean} [backState=false]
  */
 psModifyBackState(bckState)

psClearParamsStack

/**
  * $vp.psClearParamsStack()
  * <p>
  * 清空參數(shù)棧
  */
 psClearParamsStack()

psPageNext

/**
  * $vp.(location[, {params = {}, clearParamsStack = false, backState = false} = {}])
  * <p>
  * 頁面導(dǎo)航
  * @param location router location對象
  * @param {Object} [params={}] 向下一個頁面需要傳遞的參數(shù)
  * @param {Boolean} [clearParamsStack=false] 在進(jìn)行頁面導(dǎo)航的時候,是否清空參數(shù)棧,默認(rèn)為false
  * @param {Boolean} [backState=false] 設(shè)置`vuex#vplus.backState`返回狀態(tài),默認(rèn)為false
  */
 psPageNext(location, {params = {}, clearParamsStack = false, backState = false} = {})

psPageReplace

/**
  * $vp.(location[, {params = {}, isPop = true} = {}])
  * <p>
  * 頁面導(dǎo)航(基于Router),移除上一個頁面
  * <p>
  *  將會出棧頂對象,并重新設(shè)置`params`為參數(shù)棧的棧頂參數(shù)
  *  注:在調(diào)用該方法的頁面,必須是要調(diào)用`ParamsStack#psPageNext`導(dǎo)航的頁面,因為需要保證“彈棧”操作無誤,
  *  又或者設(shè)置`isPop`為false
  * @param location router location對象
  * @param {Object} [params={}] 向下一個頁面需要傳遞的參數(shù)
  * @param {Boolean} [isPop=false] 是否pop當(dāng)前頁面的參數(shù)后在進(jìn)行頁面跳轉(zhuǎn),默認(rèn)為true,防止當(dāng)前頁面
  * 不是通過`ParamsStack#psPageNext`導(dǎo)航過來的,但是由需要使用當(dāng)前方法
  */
 psPageReplace(location, {params = {}, isPop = true} = {})

psPageGoBack

/**
  * $vp.psPageGoBack({backParams = {}, clearParamsStack = false, backPopPageNumbs = -1} = {})
  * <p>
  * 頁面回退
  * @param {Object} backParams 設(shè)置回傳參數(shù)
  * @param {Boolean} clearParamsStack 是否清空參數(shù)棧
  * @param {Number} backPopPageNumbs 出棧頁面數(shù)
  */
 psPageGoBack({backParams = {}, clearParamsStack = false, backPopPageNumbs = -1} = {})

以上是“Vue如何實現(xiàn)頁面狀態(tài)保持頁面間數(shù)據(jù)傳輸”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學(xué)習(xí)更多知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!

當(dāng)前文章:Vue如何實現(xiàn)頁面狀態(tài)保持頁面間數(shù)據(jù)傳輸
網(wǎng)頁路徑:http://chinadenli.net/article22/ppccjc.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供品牌網(wǎng)站建設(shè)App開發(fā)網(wǎng)站建設(shè)微信公眾號網(wǎng)站制作定制網(wǎng)站

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

成都網(wǎng)頁設(shè)計公司