сърцевината на ajax в полимерния елемент не изпълнява функцията за отговор

Не изпълнявайте функцията за обработка на отговор, не знам защо

Извън хартиения елемент, използвайки document.getelemetbyid(), направете respnser, но когато го поставя в хартиения елемент, не правете нищо.

Ето моят код:

<link rel="import" href="/bgbower_components/polymer/polymer.html">
<link rel="import" href="/bgbower_components/core-ajax/core-ajax.html">
<polymer-element name="post-service" attributes="posts">
<template>
    <style>
        :host {
            display: none;
        }
    </style>

    <core-ajax auto url="http://yami-no-seire.hol.es/blog/api/get_recent_posts/" on-core-response="{{postsLoaded}}" handleAs="json">
    </core-ajax>
</template>
<script>
    Polymer({
        created: function () {
            this.posts = [];
        },

        /*AJAX Success Callback Method*/
        postsLoaded: function() {
        console.log("Ok");

            var respuesta = this.$.ajax

            /*document.querySelector('#student-table-template').model = {
                posts: e.detail.response
            };*/
            var data = respuesta.detail.response.posts,
                posts = [],
                el = document.createElement("div");
            // build custom object
            for (var i = 0; i < data.length; i++) {
                //escape title
                el.innerHTML = data[i].title;
                var title = el.innerHTML;
                //escape content
                el.innerHTML = data[i].excerpt;
                var excerpt = el.innerHTML;

                entradas.push({
                    url: data[i].url,
                    title: title,
                    excerpt: excerpt.replace('&nbsp;', ' ').replace('<p>', '').replace('</p>', ''),
                    modified: parseDate(data[i].modified),
                    name: data[i].author.name
                });
            }
            this.posts = posts;
        }
    });

    function parseDate(date) {
                var d = new Date(date);
                var months = ["January", "February", "March",
  "April", "May", "June", "July", "August", "September",
  "October", "November", "December"
];
                return d.getDate() + " - " + months[d.getMonth()] + " - " + d.getFullYear();
            };
</script>
</polymer-element>

Изглежда, че core-ajax не обработва заявката.


person Jordy Mendoza    schedule 21.03.2015    source източник


Отговори (1)


Автоматично намиране на възел

this.$.ajax

насочва елементи по id атрибут, който липсва във вашия core-ajax елемент:

<core-ajax auto url="(my url)" id='ajax'...

Ето работещ пример: Plunk

Редактиране: Ето как да уловите отговора в публикациитеLoaded:

 postsLoaded: function(e, detail, sender){

    console.log('postsLoaded');
    console.log(e.detail.response);
  },

Но ако не получавате дори дневника „Ok“, това може да е грешен URL адрес.

person Goce Ribeski    schedule 21.03.2015
comment
Поставих ID, поставих, все още не ми показва дневника OK от манипулатора на отговора - person Jordy Mendoza; 21.03.2015
comment
Редактирах своя URL адрес, URL адресът е ок, без полимерния елемент, реагира правилно - person Jordy Mendoza; 23.03.2015