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


TypeScript Promise.resolve方法代碼示例

本文整理匯總了TypeScript中es6-promise.Promise.resolve方法的典型用法代碼示例。如果您正苦於以下問題:TypeScript Promise.resolve方法的具體用法?TypeScript Promise.resolve怎麽用?TypeScript Promise.resolve使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在es6-promise.Promise的用法示例。


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

示例1: function

  return function(dispatch: Dispatch<IStoreState>, getState: () => IStoreState): Promise<any> {

    function onSuccess(rawItems: IMenuItemRaw[]) {
      dispatch({
        type: ActionType.FETCH_SUCCESS_REMOTE,
        data: rawItems
      } as IActionReceiveItemsFromAPI);
    }
    function onFailure(error: any) {
      dispatch({
        type: ActionType.FETCH_FAILURE,
        message: error.message || 'Fetch error'
      } as IActionFetchFailure)
    }
    let result: Promise<any>;

    let localItems = loadLocalItems();
    localItems = null;
    if (getIsFetchingStatus(getState())) {
      // If a fetch is already in progress, do not initiate another fetch. Once
      // again, notice that we do not access the structure of the store directly
      // even though we could:
      result = Promise.resolve(null);
    } else {
      // Let the app know that fetching is about to start (show loading spinner):
      dispatch({
        type: ActionType.FETCH_BEGIN
      } as IActionNotify);
      if (doesExist(localItems)) {
        // If local storage has stored data, load from it:
        dispatch({
          type: ActionType.FETCH_SUCESS_LOCAL,
          data: localItems
        } as IActionReceiveItemsFromLocal);
        result = Promise.resolve(null);
      } else {
        // Otherwise, fetch data from the API and shows the loading spinner until
        // the data has finished loading:
        result = ajax({
          url: dataFileURL,
          dataType: 'json'
        }).then(
          // Here we use the two-callback form of `then` because we want `onFailure`
          // to only handle errors from the API call and not some other internal
          // errors.  Internal errors are passed to the `catch` callback later:
          onSuccess,
          onFailure
        ).catch((error) => {
          console.log(error);
        });
      }
    }
    return result;
  }
開發者ID:huy-nguyen,項目名稱:restaurant-menu-builder,代碼行數:54,代碼來源:actions.ts

示例2: get

    get(path: string): Promise<Object> {
        if (path.indexOf("/subscriptions?") === 0) {
            return Promise.resolve({
                value: [
                    { subscriptionId: "6d867431-f573-4e78-b658-10896020cff7", displayName: "d2" }
                ]
            });
        } else if (path.indexOf("/subscriptions/") === 0) {
            return Promise.resolve({ value: [{}, {}] });
        }

        return Promise.reject(404);
    }
開發者ID:karataliu,項目名稱:monicooky,代碼行數:13,代碼來源:mcLib.spec.ts

示例3: dispatch

 .then((result) => {
     dispatch({
         type: UNLINK_USER,
         data: result.data
     })
     return Promise.resolve(result.data);
 })
開發者ID:Emunoz88,項目名稱:node-hapi-react-redux-sass-typescript-mongo-webpack-hmr-gulp,代碼行數:7,代碼來源:actions.ts

示例4: executeQueries

 executeQueries(queries: IMcQueryEntry[]): Promise<IMcResult> {
   return Promise.resolve<IMcResult>({
     list: [
       { name: "a1", value: 2 }
     ]
   });
 }
開發者ID:karataliu,項目名稱:monicooky,代碼行數:7,代碼來源:adapter.spec.ts

示例5: h

 const h = (i: number)=>{
     const f = files[i];
     if (f == null){
         if (nisFinite(mtime)){
             target[mtimef] = mtime;
         }
         return Promise.resolve(target);
     }
     const pa = path.join(dir, f);
     const base = path.basename(f, path.extname(f));
     return this.fromFile1(pa, options, cache && cache[base]).then(v=>{
         if (v !== void 0){
             target[base] = v;
         }
         // ディレクトリ中で最大のmtimeを調べている
         if (options.mtime){
             if (v != null && nisFinite(v[mtimef])){
                 // 更新日時情報持ってる
                 if (mtime < v[mtimef]){
                     mtime = v[mtimef];
                 }
                 return h(i+1);
             }else{
                 // 無いから取得しないと
                 return getMTime(pa).then(mt=>{
                     if (nisFinite(mt) && mtime < mt){
                         mtime = mt;
                     }
                     return h(i+1);
                 });
             }
         }
         return h(i+1);
     });
 };
開發者ID:uhyo,項目名稱:my-load-data,代碼行數:35,代碼來源:loader.ts

示例6: jsLoader

export default function jsLoader(path: string): Promise<any>{
    try {
        return Promise.resolve(require(path));
    }catch (e){
        return Promise.reject(e);
    }
}
開發者ID:uhyo,項目名稱:my-load-data,代碼行數:7,代碼來源:js.ts

示例7: runPayload

function runPayload(payload:Payload) {
    if (payload.isTarget()) {
        return payload.run();
    } else {
        return Promise.resolve(false)
    }
}
開發者ID:verath,項目名稱:router-hijack,代碼行數:7,代碼來源:index.ts

示例8: promptName

    promptName(name: string = ''): Thenable<string> {
        name = name.trim();

        if (!this.utils.isEmpty(name)) {
            this.title = name;

            name = this.utils.kebabCase(name).toLowerCase();
            let valid = validate(name);

            if (this.utils.isArray(valid.errors) || this.utils.isArray(valid.warnings)) {
                this.ui.warn('');
                this.utils.forEach(valid.errors, (err: string) => {
                    this.ui.warn(err);
                });

                this.utils.forEach(valid.warnings, (err: string) => {
                    this.ui.warn(err);
                });
                this.ui.warn('');
            } else {
                return Promise.resolve(name);
            }
        }

        return this.ui.prompt([
            { name: 'name', type: 'input', message: `What is the name of your app?` }
        ]).then((answer: { name: string; }) => {
            return this.promptName(answer.name);
        });
    }
開發者ID:DevanB,項目名稱:platypi-cli,代碼行數:30,代碼來源:index.ts

示例9: function

    return function (dispatch: Dispatch, getState: () => any): any {
        if (!getState().sandwiches.isShopOpen) {

            // You don’t have to return Promises, but it’s a handy convention
            // so the caller can always call .then() on async dispatch result.

            return Promise.resolve();
        }

        // We can dispatch both plain object actions and other thunks,
        // which lets us compose the asynchronous actions in a single flow.

        return dispatch(
            makeASandwichWithSecretSauce('My Grandma')
        ).then(() =>
                Promise.all([
                    dispatch(makeASandwichWithSecretSauce('Me')),
                    dispatch(makeASandwichWithSecretSauce('My wife'))
                ])
        ).then(() =>
                dispatch(makeASandwichWithSecretSauce('Our kids'))
        ).then(() =>
                dispatch(getState().myMoney > 42 ?
                        withdrawMoney(42) :
                        apologize('Me', 'The Sandwich Shop')
                )
        );
    };
開發者ID:ansarbek,項目名稱:DefinitelyTyped,代碼行數:28,代碼來源:redux-thunk-tests.ts


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