當前位置: 首頁>>代碼示例>>TypeScript>>正文


TypeScript vuex.mapActions函數代碼示例

本文整理匯總了TypeScript中vuex.mapActions函數的典型用法代碼示例。如果您正苦於以下問題:TypeScript mapActions函數的具體用法?TypeScript mapActions怎麽用?TypeScript mapActions使用的例子?那麽, 這裏精選的函數代碼示例或許可以為您提供幫助。


在下文中一共展示了mapActions函數的9個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的TypeScript代碼示例。

示例1: connectToComponent

    function connectToComponent(
      nameOrComponent: string | Component,
      optionalComponent?: Component
    ): Component {
      let Component: Component, name: string
      if (typeof nameOrComponent !== 'string') {
        Component = nameOrComponent
        name = getOptions(Component).name || 'wrapped-anonymous-component'
      } else {
        Component = optionalComponent!
        name = nameOrComponent
      }

      const propKeys = keys(
        stateToProps,
        gettersToProps,
        actionsToProps,
        mutationsToProps,
        methodsToProps
      )

      const eventKeys = keys(
        actionsToEvents,
        mutationsToEvents,
        methodsToEvents
      )

      const containerProps = omit(collectProps(Component), propKeys)
      const containerPropsKeys = Object.keys(containerProps)

      const options = {
        name: `connect-${name}`,
        props: containerProps,
        components: {
          [name]: Component
        },
        computed: merge(mapState(stateToProps), mapGetters(gettersToProps)),
        methods: merge(
          mapActions(merge(actionsToProps, actionsToEvents)),
          mapMutations(merge(mutationsToProps, mutationsToEvents)),
          mapValues(merge(methodsToProps, methodsToEvents), bindStore)
        )
      }

      insertLifecycleMixin(options, lifecycle)
      insertRenderer(
        options,
        name,
        propKeys.concat(containerPropsKeys),
        eventKeys
      )

      if (transform) {
        transform(options, lifecycle)
      }

      return typeof Component === 'function' ? Vue.extend(options) : options
    }
開發者ID:ktsn,項目名稱:vuex-connect,代碼行數:58,代碼來源:connect.ts

示例2: function

      currentId: null,
      isModify: false
    }
  },

  updated: function(){
    if(!this.currentId && this.apiList.length){
      this.currentId = this.apiList[0]._id
    }
  },

  components:{
    AddApi
  },
  methods: {
    ...mapActions(['remove_apiList', 'modify_apiList']),
    modifyApi(): void {
      this.apiList.map( (item:ITApiListInfo) => {
        if(item._id === this.currentId){
          this.apiName = item.name
          this.apiDesc = item.desc
          this.isModify = true
        }
      })
    },
    ChangeApi(ev): void {
      this.currentId = ev.target.value
    },
    async removeApi(): Promise<any> {
      let { currentId } = this
      if(currentId){
開發者ID:jfengsky,項目名稱:cquick,代碼行數:31,代碼來源:Modify.ts

示例3: function

  template: `<div>
              <ul>
                <li v-for="item in routes">
                  <router-link :to="{path: item.path}">{{item.name}}</router-link>
                </li>
              </ul>
            </div>`,
  created: function () {
    this.fetchApiList()
    this.fetchMockList()
    this.fetchFileMockList()
  },
  methods: {
    ...mapActions([
      'updata_apiList',
      'updata_mockList',
      'updata_fileMockList'
    ]),

    // 異步請求apiList
    async fetchApiList(){
      let fetchBack = await FETCH_API_LIST({
        type: 'search'
      })
      this.updata_apiList(fetchBack)
    },
    async fetchMockList(){
      let fetchMockBack = await FETCH_MOCK_LIST({
        type: 'search'
      })
      this.updata_mockList(fetchMockBack)
開發者ID:jfengsky,項目名稱:cquick,代碼行數:31,代碼來源:Menu.ts

示例4: function

  },
  components:{},
  mounted: function(){
    this.mockList.map(({_id, desc, name}: ITMockListInfo)=> {
      if(_id === this.mockId) {
        this.desc = desc
        this.name = name
      }
    })
    
    // 請求code
    this.fetchCode()

  },
  methods:{
    ...mapActions(['remove_mockList']),
    async modifMock(){
      let saveState = await FETCH_MOCK_LIST({
        name: this.name,
        type: 'modify',
        pid: this.pid,
        code: this.code,
        desc: this.desc,
        id: this.mockId
      })
      if(saveState.ok === 1){

        // 偷懶
        window.location.reload()
        // this.callback()
      }
開發者ID:jfengsky,項目名稱:cquick,代碼行數:31,代碼來源:EditMock.ts

示例5: data

                   代碼:<textarea v-model="code"></textarea>
                 </label>
               </div>
               <button @click="addCode">新增</button>
             </div>`,
 props:["pid", "pname"],
 data(){
   return {
     desc: '',
     code: ''
   }
 },
 components:{},
 methods:{
   ...mapActions([
     'updata_mockList'
   ]),
   async addCode(){
     if(!this.code && !this.desc){
       return false
     }
     let saveState = await FETCH_MOCK_LIST({
       type: 'save',
       pid: this.pid,
       code: this.code,
       desc: this.desc
     })
     this.updata_mockList(saveState)
     this.desc = ''
     this.code = ''
   }
開發者ID:jfengsky,項目名稱:cquick,代碼行數:31,代碼來源:AddMock.ts

示例6:

      'isLoading',
      'isOnline',
      'isDev',
      'constants',
      'errorCode'
    ])
  },
  methods: {
    ...mapActions('global', [
      'calcServerTimeOffset',
      'startLoading',
      'stopLoading',
      'offlineEventListener',
      'onlineEventListener',
      'beforeunloadAlertEventListener',
      'beforeunloadCookieEventListener',
      'windowResizeEventListener',
      'updateTitle',
      'updateErrorCode',
      'openNewTab',
      'moveTo',
      'moveToMypage',
      'reload',
      'closeTab',
      'getCookie',
      'setCookie',
      'removeCookie'
    ])
  }
}
開發者ID:tic40,項目名稱:archives,代碼行數:30,代碼來源:global.ts

示例7: ChangeMock

    this.fileMockList

    if (!this.mockId && this.fileMockList.length) {
      this.fileMockList.some((item: any): any => {
        if(item.pid === this.id){
          this.mockId = item.mockId
        }
      })
    }
  },
  components: {
    AddMock,
    EditMock
  },
  methods: {
    ...mapActions([]),
    ChangeMock(ev) {
      this.mockId = ev.target.value
      this.isEdit = false
      FETCH_MOCK_CHANGE({
        type: 'modify',
        pid: this.mockId,
        id: this.id
      })
    },
    clickHandleEdit() {
      this.isEdit = true
    },
    modifyBack() {
      this.isEdit = false
    }
開發者ID:jfengsky,項目名稱:cquick,代碼行數:31,代碼來源:ApiInfo.ts

示例8:

//import { mapGetters, mapActions } from 'vuex'
import { mapActions } from 'vuex'

export default {
  methods: {
    ...mapActions('lessonRoom', ['openNewWindowForPreparation']),
    ...mapActions('modal', ['showModal', 'hideModal'])
  }
}
開發者ID:tic40,項目名稱:archives,代碼行數:9,代碼來源:modal.ts

示例9: data

              </label>
              <br />
              <label>
                接口描述:<textarea v-model="apiDesc"></textarea>
              </label>
              <br />
              <button @click="addApi">新增接口</button>
            </div>`,
  data() {
    return {
      apiName: '',
      apiDesc: ''
    }
  },
  methods: {
    ...mapActions(['updata_apiList']),
    async addApi(): Promise<any> {
      let {
        apiName,
        apiDesc
      } = this

      if (apiName && apiDesc) {
        let addParam: ITFetchApiList = {
          type: 'save',
          name: apiName,
          desc: apiDesc
        }
        let addState = await FETCH_API_LIST(addParam)
        this.updata_apiList(addState)
        this.apiName = ''
開發者ID:jfengsky,項目名稱:cquick,代碼行數:31,代碼來源:AddApi.ts


注:本文中的vuex.mapActions函數示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。