使用Ajax编辑要点

时间:2018-09-15 17:55:11

标签: javascript ajax github gist

如何使用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);
});

documentation没有提供清晰的示例。

它返回JSON并且状态为OK 200,但要点未更新。

如果我对POST使用方法,它将显示状态404。

1 个答案:

答案 0 :(得分:1)

我编写了这个可处理所有内容的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