Axios,Typescript和Promises

时间:2017-09-16 22:24:30

标签: typescript vue.js axios

这可能更像是一个TypeScript问题。我有一个REST方法,通过Vue操作在我的http库中调用。我希望resolve()方法返回类型化的数组,但除非我在action.ts&#34中进行转换,然后"方法,我在类型{}'

中不存在' .length

有没有办法不必将结果重新转换为我的类型数组,因为它已经在http.ts方法中完成了?

http.ts(部分)

getapps() {        
        return new Promise((resolve, reject) => {
            this.axios.post('/account/getapps').then((response) => {
                resolve(response.data as DomainAppType[]);
            }, (err) => {
                reject(err);
            });
         });
    }

action.ts

import { DomainAppType } from '../models/domainApps';

var actions = {
    LOGIN: function ({ commit }, params) {
        http.getapps(params.email, params.password).then(apps => {
            var appList = <DomainAppType[]>apps;
            console.log(appList.length);
        }).catch((err) => {
            console.log(JSON.stringify(err));
        })

      }
}
export default actions

1 个答案:

答案 0 :(得分:5)

您应该声明方法的返回类型。

例如:

getApps (): Promise<DomainAppType[]> {
    return new Promise((resolve, reject) => {...});
}

不幸的是,正在解决的问题并没有被编译器当作预期的泛型类型。