iron-ajax找不到generateRequest() - 方法

时间:2017-09-29 19:46:53

标签: polymer iron-ajax

我是Polymer的新手,并尝试通过iron-ajax创建一个ajax调用。我遇到了一个错误,generateRequest()未定义。

聚合物1正在使用中。

我使用此命令安装了iron-ajax:bower install --save PolymerLabs/promise-polyfill#1

正如您所看到的,我使用<link rel="import" href="../bower_components/promise-polyfill/promise-polyfill-lite.html">

加载它

我将它与一些例子进行比较,但找不到错误。 有人有想法或解决方案吗?

这是代码:

<!--
@license
Copyright (c) 2016 The Polymer Project Authors. All rights reserved.
This code may only be used under the BSD style license found at http://polymer.github.io/LICENSE.txt
The complete set of authors may be found at http://polymer.github.io/AUTHORS.txt
The complete set of contributors may be found at http://polymer.github.io/CONTRIBUTORS.txt
Code distributed by Google as part of the polymer project is also
subject to an additional IP rights grant found at http://polymer.github.io/PATENTS.txt
-->

<link rel="import" href="../bower_components/polymer/polymer.html">
<link rel="import" href="shared-styles.html">
<link rel="import" href="../bower_components/promise-polyfill/promise-polyfill-lite.html">
<dom-module id="my-view2">
  <template>
    <style include="shared-styles">
      :host {
        display: block;

        padding: 10px;
      }
    </style>

    <div class="card">
      <div class="circle">2</div>
      <h1>View Two</h1>
      <p>Demo output</p>
    </div>

    <template is="dom-repeat" items="[[repos]]">
      <span>{{items.name}}</span>
    </template>
    <button on-click="setajax">Click me</button>

    <iron-ajax
            id="ajax"
            url=""
            params='{"type":"all"}'
            handle-as="json"
            on-response="hresponse"
            debounce-duration="300" >
    </iron-ajax>
  </template>

  <script>
    Polymer({
      is: 'my-view2',
        setajax: function () {
            this.$.ajax.url = "https://api.github.com/users/burczu/repos";
            this.$.ajax.params= {"type":"all"};
            this.$.ajax.generateRequest();
      },
        hresponse: function(request) {
            console.log(request.detail.response);
            console.log(this.$.ajax.lastResponse);
        }
    });
  </script>
</dom-module>

1 个答案:

答案 0 :(得分:3)

您需要安装iron-ajax

bower install --save PolymerElements/iron-ajax

然后,您可以使用以下代码导入:

<link rel="import" href="../bower_components/iron-ajax/iron-ajax.html">

执行上述操作后,您的代码将会正常工作。