Skip to content
/ refetch Public

frech remote data with ajax, jsonp, cache, promise A+

Notifications You must be signed in to change notification settings

Lobos/refetch

Repository files navigation

refetch

服务端数据获取,支持ajax和jsonp,使用promise A+规范,支持cache。ajax使用了qwest(修改了qwest返回接口参数顺序)

Install

npm install refetch

Api

refetch[method](url, data, options)

method: get, post, put, delete, jsonp

url: 必填

data: Object

options:

  • dataType: method 为jsonp时无效。可选值 post (default), json, text, arraybuffer, blob, document, formdata
  • responseType: method 为jsonp时无效。可选值 json (default), text, xml, arraybuffer, blob, document
  • headers: method 为jsonp时无效。object
  • timeout: 毫秒
  • cache: 缓存,单位秒,大于0时有效。
  • storage: bool,是否使用localStorage缓存,默认为false。
  • withCredentials: method 为jsonp时无效。是否支持跨域 default false
  • async: method 为jsonp时无效。是否同步 default true
  • delay: 延时处理,单位毫秒,默认为0。

Example

// jsonp 无xhr

refetch.get('hello.html')
    .then(function () {response, xhr} {
        console.log(response);
    });

refetch.post('hello.html', { name: 'world' })
    .then(function (response, xhr) {
        console.log(response);
    })
    .catch(function (error, response, xhr) {
        console.log(error);
    });

create

使用预设参数定制一个fetch,更加函数式的解决方案

const fetch = Refetch.create({
    data: {},           // 数据,会被get等方法参数merge
    options: {},        // 请求参数
    promise: function   // 预处理方法
})
fetch[get|post|jsonp|put|delete](...)

// =========================

const fetch = Refetch.create({
    data: { a: 1, b: 2 },
    options: { dataType: 'json' },
    promise: (f) => f.then((res, xhr) => {
        if (res.success) {
           return res.data;
        } else {
            // ... 处理异常
            // 返回 new Error,cache将会忽略这个错误数据
            return new Error(res.msg);
        }
    })
});

fetch.get('/xxx')  // get /xxx?a=1&b=2  dataType=json
fetch.post('/xxx', { b: 3, c: 4 }, { dataType: 'text' }) // post /xxx a=1&b=3&c=4  dataType='text'

setDefaultOptions

设置默认options

fetch.setDefaultOptions({ timeout: 30000, cache: 60 });
fetch.get(...)

setDefaultData

设置默认数据,每次请求会自动提交

fetch.setDefaultData({ token: xxxxxxx });
fetch.get(...)

默认数据处理

提供了一个setPeer方法,用来预处理返回数据

const peer = (promise) => promise.then((res, xhr) => {
    if (res.success) {
       return res.data;
    } else {
        // ... 处理异常
        // 返回 new Error,cache将会忽略这个错误数据
        return new Error(res.msg);
    }
})
// 增加默认异常处理
.catch((err, res, xhr) => {
    // ... 处理异常
});

fetch.setPeer(peer);

fetch.get(...);

About

frech remote data with ajax, jsonp, cache, promise A+

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages