使用 ajax 编辑要点



如何使用 ajax 更新要点?我试过这个:

$.support.cors = true;
$.ajax({
crossDomain: true,
//method: 'PATCH',
//method: 'POST',
//type: 'PATCH',
url: 'https://api.github.com/gists/<GIST_ID>',
data: '{"description" : "some description text","public" : true, "files" : { "myfile.txt" : { "content" : "file edited via ajax", "filename" : "myfile.txt" } }}',
beforeSend: function(xhr) {
xhr.setRequestHeader("Authorization","Basic <USER>:<PASS>");
}
}).done(function(response) {
console.log(response);
});

该文档未提供明确的示例。

它返回一个 JSON 和状态 OK 200,但要点不会更新。

如果我使用方法POST它将给出状态 404。

我写了这个处理这一切的javascript对象:

/**
* Credit: http://techslides.com/github-gist-api-with-curl-and-ajax
* https://developer.github.com/v3/gists/
* @example
* var g = new Gist();
* g.gistID = 'ae7f4db52bbf76051e25e26fb05712c0';
* g.token = '2590a460f653d23c4f61c6774b7a41296aea9028';
*
* g.create({
*    description: 'new gist',
*    public: true,
*    files: {
*        'file1.txt': {
*            'content': 'file contents'
*       }
*     }
* }, function(data) {
*        // callback
* });
*/
var Gist = function() {
$.support.cors = true; // Whithout this ajax will not work in IE 9.
$.ajaxSetup({ cache: false }); // Disable ajax cache globally.
this.gistID = '';
this.token = '';
var self = this;
this.newToken = function(user, pass, callback) {
$.ajax({
url: 'https://api.github.com/authorizations',
type: 'POST',
beforeSend: function(xhr) {
xhr.setRequestHeader("Authorization", "Basic " + btoa(user + ':' + pass));
},
data: JSON.stringify({
scopes: ['gist'],
note: 'new token request from ajax ' + new Date()
})
}).always(function(data, txtStatus, err) {
if (typeof callback === 'function') callback(data);
});
}
this.create = function(data, callback) {
$.ajax({
url: 'https://api.github.com/gists',
type: 'POST',
beforeSend: function(xhr) {
xhr.setRequestHeader('Authorization', 'token ' + self.token);
},
data: JSON.stringify(data)
}).always(function(data, txtStatus, err) {
if (typeof callback === 'function') callback(data);
});
}
this.edit = function(data, callback) {
$.ajax({
url: 'https://api.github.com/gists/' + self.gistID,
type: 'PATCH',
beforeSend: function(xhr) {
xhr.setRequestHeader('Authorization', 'token ' + self.token);
},
data: JSON.stringify(data)
}).always(function(data, txtStatus, err) {
if (typeof callback === 'function') callback(data);
});
}
}

信用:http://techslides.com/github-gist-api-with-curl-and-ajax

最新更新