首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >问答首页 >如何触发聚合-3.x中按钮点击的铁-ajax?

如何触发聚合-3.x中按钮点击的铁-ajax?
EN

Stack Overflow用户
提问于 2018-08-28 07:32:41
回答 1查看 1.6K关注 0票数 1

我正在创造一个聚合物元素,使用铁-阿贾克斯。这将击中一个公共API来获取一个随机的fox imageUrl,并在DOM中显示。

需求

在单击button时,我想对api进行新的调用,这将给我新的url。目前我正在使用<button type="button" onClick="window.location.reload();">。但这会刷新页面。

问题

我浏览了这个StackOverflow solution并将其更改为version-3解决方案。

代码语言:javascript
代码运行次数:0
运行
复制
class MyFox extends PolymerElement {
  static get template() {
    return html`
      <dom-bind>
      <template id="temp"> 
          <iron-ajax
            auto
            id="dataAjax"
            url=""
            handle-as="json"
            on-response="handleResponse"
            id="apricot">
          </iron-ajax>

          <button type="button" onClick="window.location.reload();">Next Image</button>
          <br> <br>
          <img src="[[imgUrl]]" width="300">
      </template>
      </dom-bind>
    `;
  }
  static get properties() {
    return {
      prop1: {
        type: String,
        value: 'my-fox',
      },
      imgUrl: {
        type: String,
      }
    };
  }
  handleResponse(event, res) {
    this.imgUrl = res.response.image; 
  }
  nextImg() {
    // new call to iron-ajax for new image
    var temp = document.querySelector('#temp');
    temp.$.dataAjax.generateRequest();
  }
}

window.customElements.define('my-fox', MyFox);

但是我得到了以下错误。侦听器方法未定义

问题

如何手动触发iron-ajax按钮点击,这样我就可以得到新的response or imageUrl和页面没有刷新?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2018-08-28 11:22:31

您的web组件中有几个错误

代码语言:javascript
代码运行次数:0
运行
复制
class MyFox extends PolymerElement {
  static get template() {
    return html`
          <iron-ajax
            auto
            id="dataAjax"
            url=""
            handle-as="json"
            on-response="handleResponse">
          </iron-ajax>

          <button type="button" on-tap="nextImg">Next Image</button>
          <br> <br>
          <img src="[[imgUrl]]" width="300">
    `;
  }
  static get properties() {
    return {
      prop1: {
        type: String,
        value: 'my-fox',
      },
      imgUrl: {
        type: String,
      }
    };
  }
  handleResponse(event, res) {
    this.imgUrl = res.response.image; 
  }
  nextImg() {
    // new call to iron-ajax for new image
    this.$.dataAjax.generateRequest();
  }
}

window.customElements.define('my-fox', MyFox);
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/52052416

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档