- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
如何在 polymer 的 dom-repeat 模板中显示现有项目的变化?
我真的尝试了所有我能想到的,我可以在 polymer 文档或网络上找到。但没有任何效果。在下面,您会发现一个 html 页面,它使用一个小列表,并在您单击更改按钮时尝试将列表中的一个条目更改为另一个值。但是唯一会更改列表中更改按钮旁边的项目的是被注释掉的行。所有其他线路都尝试了,但失败了。
我知道重新渲染模板是一项耗时的任务,只有在必要时才应该进行,而 Polymer 会尽量避免这种情况。但为什么我(从他们世界之神的代码来看 ^^)不可能故意强制渲染?
创建一个完整的新对象,从列表中删除旧项目并插入新对象的方法(这就是注释行所做的)是一种解决方法,但当项目更复杂时,这确实是一项巨大的工作并具有甚至不显示的属性或数组。
我错过了什么?我没有尝试什么?如果有人能告诉我我可以做些什么来完成这样一个(从我的 Angular 来看)简单且非常常见的任务,我将非常高兴。
编辑(已解决):Tomasz Pluskiewicz 的解决方案部分成功。但我更新了代码以显示我当前的问题。项目的名称使用方法 format(...) 绑定(bind)。单击按钮时,该项目将从列表中删除。这很好用。但是如果您删除列表的最后一项,那么列表中新的最后一项的名称应该是“Last”。当名称直接绑定(bind)到属性名称时,这也有效。但如果我想对名称进行一些格式化(例如用 # 括起来),则不会更新此项目的显示。
EDIT2(部分解决):下一个不起作用的示例发生在为显示值而调用的方法中的值发生更改时。如果多次单击更改按钮,可以在示例中看到这一点。它增加了一个内部计数器,相应的文本将显示这个值。但这仅适用于计数器的第一次更改。随后的点击不会再次改变显示。显示屏显示第一次点击后计数器的值。但是,如果单击另一个更改按钮,则此按钮前面的文本会显示增加的计数器值。但也只有一次。它也不会显示后续点击的变化。 notifyPath 方法似乎检查值是否已更改,但没有考虑在用于显示值的方法内部,可能已更改某些内容以以另一种方式显示数据。
我在这个例子中包含了一个部分解决方案。如果被调用的方法有一个参数,当方法中的某些内容发生变化时该参数也会发生变化,那么将执行更新。这可以在与参数 displayEnforcer - format(item.name,displayEnforcer) 绑定(bind)的第二个变量中看到。每次更改计数器时,此变量都会设置为随机值。这会触发显示更新。
但这是一个非常奇怪的解决方案,没有必要。如果有人能更好地解决这个问题,那就太好了。
<link rel="import" href="components/bower_components/polymer/polymer.html">
<link rel="import" href="components/bower_components/paper-button/paper-button.html">
<dom-module id="polymer-test">
<template>
<table>
<template id="tpl" is="dom-repeat" items="{{list}}">
<tr>
<td>{{item.id}} - {{format(item.name)}}- {{format(item.name,displayEnforcer)}}</td>
<td><paper-button raised on-tap="tapDelete">delete</paper-button></td>
<td><paper-button raised on-tap="tapChange">change</paper-button></td>
</tr>
</template>
</table>
</template>
</dom-module>
<script>
Polymer(
{
is: "polymer-test",
properties:
{
count: {type: Number, value:0}
,list: {type: Array, value: [{id:0,name:"First"}
,{id:1,name:"Second"}
,{id:2,name:"Third"}
,{id:3,name:"Fourth"}
,{id:4,name:"Fifth"}
,{id:5,name:"Last"}
]}
,displayEnforcer: {type:Number,value:Math.random()}
},
format: function(name,dummy)
{
return "#" + name + " - " + this.count + "#";
},
tapChange: function(e)
{
this.count++;
this.displayEnforcer = Math.random();
this.notifyPath("list." + (e.model.index) + ".name","changed");
},
tapDelete: function(e)
{
if(this.list.length == 1)
return;
this.splice("list",e.model.index,1);
if(this.list.length > 0)
this.list[this.list.length-1].name = "Last";
this.notifyPath("list." + (this.list.length-1) + ".name",this.list[this.list.length-1].name);
}
});
</script>
最佳答案
您可以使用 notifyPath
刷新单个列表元素属性的绑定(bind):
tapChange: function(e) {
this.notifyPath('list.' + e.model.index + '.name', 'changed');
}
参见:https://github.com/Polymer/polymer/issues/2068#issuecomment-120767748
这种方式不会重新渲染整个中继器,而只是更新必要的数据绑定(bind)节点。
编辑
你的 format
函数没有得到更新,因为它不使用作为项目名称的通知路径。当您删除一个元素时,呈现的转发器中该元素的索引不会改变,即使实际项目发生变化也是如此。换句话说,当你删除第五个元素时,索引 4 仍然是 4。
作为解决方法,您可以添加 item.name
至 format
调用以便在您通知该路径时刷新它:
<td>{{item.id}} - {{format(index, item.name)}}</td>
您甚至不必在示例中使用该值。重新评估绑定(bind)就足够了。
关于javascript - 我如何强制在 Polymer 中进行模板更新?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37341743/
我查看了网站上的一些问题,但还没有完全弄清楚我做错了什么。我有一些这样的代码: var mongoose = require('mongoose'), db = mongoose.connect('m
基本上,根据 this bl.ocks,我试图在开始新序列之前让所有 block 都变为 0。我认为我需要的是以下顺序: 更新为0 退出到0 更新随机数 输入新号码 我尝试通过添加以下代码块来遵循上述
我试图通过使用随机数在循环中设置 JSlider 位置来模拟“赛马”的投注结果。我的问题是,当然,我无法在线程执行时更新 GUI,因此我的 JSlider 似乎没有在竞赛,它们从头到尾都在运行。我尝试
该功能非常简单: 变量:$table是正在更新的表$fields 是表中的字段,$values 从帖子生成并放入 $values 数组中而$where是表的索引字段的id值$indxfldnm 是索引
让我们想象一个环境:有一个数据库客户端和一个数据库服务器。数据库客户端可以是 Java 程序或其他程序等;数据库服务器可以是mysql、oracle等。 需求是在数据库服务器上的一个表中插入大量记录。
在我当前的应用程序中,我正在制作一个菜单结构,它可以递归地创建自己的子菜单。然而,由于这个原因,我发现很难也允许某种重新排序方法。大多数应用程序可能只是通过“排序”列进行排序,但是在这种情况下,尽管这
Provisioning Profile 有 key , key 链依赖于它。我想知道 key 什么时候会改变。 Key will change after renew Provisioning Pr
截至目前,我在\server\publications.js 中有我的 MongoDB“选择”,例如: Meteor.publish("jobLocations", function () { r
我读到 UI 应该始终在主线程上更新。但是,当谈到实现这些更新的首选方法时,我有点困惑。 我有各种函数可以执行一些条件检查,然后使用结果来确定如何更新 UI。我的问题是整个函数应该在主线程上运行吗?应
我在代理后面,我无法构建 Docker 镜像。 我试过 FROM ubuntu , FROM centos和 FROM alpine ,但是 apt-get update/yum update/apk
我构建了一个 Java 应用程序,它向外部授权客户端公开网络服务。 Web 服务使用带有证书身份验证的 WS-security。基本上我们充当自定义证书颁发机构 - 我们在我们的服务器上维护一个 ja
因此,我有时会在上传新版本时使用 app_offline.htm 使应用程序离线。 但是,当我上传较大的 dll 时,我收到黄色错误屏幕,指出无法加载 dll。 这似乎与我对 app_offline.
我刚刚下载了 VS Apache Cordova Tools Update 5,但遇到了 Node 和 NPM 的问题。我使用默认的空白 cordova 项目进行测试。 版本 如果我在 VS 项目中对
所以我有一个使用传单库实例化的 map 对象。 map 实例在单独的模板中创建并以这种方式路由:- var app = angular.module('myApp', ['ui', 'ngResour
我使用较早的 Java 6 u 3 获得的帧速率是新版本的两倍。很奇怪。谁能解释一下? 在 Core 2 Duo 1.83ghz 上,集成视频(仅使用一个内核)- 1500(较旧的 java)与 70
我正在使用 angular 1.2 ng-repeat 创建的 div 也包含 ng-click 点击时 ng-click 更新 $scope $scope 中的变化反射(reflect)在使用 $a
这些方法有什么区别 public final void moveCamera(CameraUpdate更新)和public final void animateCamera (CameraUpdate
我尝试了另一篇文章中某人评论中关于如何将树更改为列表的建议。但是,我在某处(或某物)有未声明的变量,所以我列表中的值是 [_G667, _G673, _G679],而不是 [5, 2, 6],这是正确
实现以下场景的最佳方法是什么? 我需要从java应用程序调用/查询包含数百万条记录的数据库表。然后,对于表中的每条记录,我的应用程序应该调用第三方 API 并获取状态字段作为响应。然后我的应用程序应该
只是在编写一些与 java 图形相关的代码,这是我今天的讲座中的非常简单的示例。不管怎样,互联网似乎说更新不会被系统触发器调用,例如调整框架大小等。在这个例子中,更新是由这样的触发器调用的(因此当我只
我是一名优秀的程序员,十分优秀!