gpt4 book ai didi

javascript - Polymer()中的回调;当显示元素时

转载 作者:太空宇宙 更新时间:2023-11-04 13:29:38 25 4
gpt4 key购买 nike

每次显示元素时触发的 Polymer({}) 对象中是否有可用的回调?

ready 不适合,因为它是在初始页面加载时创建元素时调用的。

每次路由更改和显示我的元素时,我都需要一个事件或回调。

为什么我需要这个?如果设置了某个请求参数,我有一个行为不同的元素。所以我需要检查每个负载是否设置了参数。

编辑:

我通过在我的路由函数中的元素显示上做我需要做的事情来解决我的要求:

page("/app/list", function() {
document.querySelector("my-list").$.loadList.generateRequest();
app.route = "list";
});

最佳答案

与此同时,我还发现了 app-route,它还具有调用路由方法或查看更改的功能。

你可以在这里阅读:

https://www.polymer-project.org/1.0/toolbox/routing#take-action-on-route-changes

这是一个工作示例:

<!DOCTYPE html>
<html>
<head>
<script src="bower_components/webcomponentsjs/webcomponents-lite.js"></script>
<link rel="import" href="bower_components/polymer/polymer.html" />
<link rel="import" href="bower_components/app-route/app-location.html" />
<link rel="import" href="bower_components/app-route/app-route.html" />
<link rel="import" href="bower_components/iron-pages/iron-pages.html" />
</head>
<body>
<container-element></container-element>
</body>
</html>

<dom-module id="container-element">
<template>
<app-location route="{{route}}" use-hash-as-path></app-location>
<app-route route="{{route}}" pattern=":view" data="{{routeData}}"></app-route>
<a href="#page1">Page 1</a> | <a href="#element1">Page 2</a>
<iron-pages selected="[[routeData.view]]" attr-for-selected="name">
<div name="page1">This is Page 1.</div>
<x-element1 name="element1"></x-element1>
</iron-pages>
</template>
<script type="text/javascript">
Polymer({
is : "container-element",
observers : [ "_viewChanged(routeData.view)" ],
_viewChanged : function(view) {
if (view) {
if (view === "element1") {
document.querySelector("x-element1").test();
}
}
}
});
</script>
</dom-module>

<dom-module id="x-element1">
<template><p>This is Element 1.</p></template>
<script type="text/javascript">
Polymer({
is : "x-element1",
test : function() {
console.log("Callback of Element 1 called.");
}
});
</script>
</dom-module>

关于javascript - Polymer()中的回调;当显示元素时,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32258708/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com