Polymer 1.0:排序 dom-重复
Polymer 1.0: Sorting dom-repeat
How do I sort the data in this jsBin by item.order
。
(Documentation)
http://jsbin.com/zoqaqivaba/edit?html,output
<html>
<head>
<title>My Element</title>
<script data-require="polymer@*" data-semver="1.0.0" src="http://www.polymer-project.org/1.0/samples/components/webcomponentsjs/webcomponents-lite.js"></script>
<script data-require="polymer@*" data-semver="1.0.0" src="http://www.polymer-project.org/1.0/samples/components/polymer/polymer.html"></script>
<base href="http://element-party.xyz/" />
<link rel="import" href="all-elements.html" />
</head>
<body>
<dom-module id="my-element">
<template>
<firebase-collection location="https://dinosaur-facts.firebaseio.com/dinosaurs"
data="{{items}}"></firebase-collection>
<paper-input label="Search"
value="{{searchString::input}}"></paper-input>
<div>[[searchString]]</div>
<div>[[sortby]]</div>
<paper-dropdown-menu label="Sort by">
<paper-menu class="dropdown-content"
selected="{{sortby}}"
attr-for-selected="data-sortby">
<paper-item data-sortby="none" >None </paper-item>
<paper-item data-sortby="order">Order</paper-item>
</paper-menu>
</paper-dropdown-menu>
<template is="dom-repeat" items="{{items}}" as="item"
filter="{{computeFilter(searchString)}}"
sort="{{computeSort(sortby)}}">
<div>[[item.__firebaseKey__]], [[item.order]]</div>
</template>
</template>
<script>
Polymer({
is: "my-element",
computeFilter: function(string) {
if (!string) {
// set filter to null to disable filtering
return null;
} else {
// return a filter function for the current search string
string = string.toLowerCase();
return function(item) {
var name = item.__firebaseKey__.toLowerCase();
var order = item.order.toLowerCase();
return (name.indexOf(string) != -1 ||
order.indexOf(string) != -1);
};
}
},
computeSort: function(string) {
/* What function goes here? To sort by 'item.order' in reverse.
function(a, b) {
return b[string] - a[string];
}
*/
},
properties: {
items: {
type: Array
}
}
});
</script>
</dom-module>
<my-element></my-element>
</body>
</html>
您的排序未绑定到 属性,因此不需要花括号 {}
。
您需要将排序函数的格式设置为函数形式,该函数采用两个参数(每个参数对应一个要排序的值)并且 returns -1、1 或 0 基于以下规则:
- 如果 compareFunction(a, b) 小于 0,将 a 排序到比 b 低的索引,即 a 在前。
- 如果 compareFunction(a, b) returns 0,保持 a 和 b 彼此不变,但对所有不同元素进行排序。注意:ECMAscript 标准不保证这种行为,因此并非所有浏览器(例如至少可以追溯到 2003 年的 Mozilla 版本)都遵守这一点。
- 如果 compareFunction(a, b) 大于 0,则将 b 排序为比 a 低的索引。
有关详细信息,请参阅 Array.prototype.sort()
http://jsbin.com/zaxogonuxa/edit?html,output
<template>
<firebase-collection location="https://dinosaur-facts.firebaseio.com/dinosaurs" data="{{items}}"></firebase-collection>
<paper-input label="Search" value="{{searchString::input}}"></paper-input>
<div>[[searchString]]</div>
<div>[[sortby]]</div>
<paper-dropdown-menu label="Sort by">
<paper-menu class="dropdown-content" selected="{{sortby}}" attr-for-selected="data-sortby">
<paper-item data-sortby="none">None </paper-item>
<paper-item data-sortby="order">Order</paper-item>
</paper-menu>
</paper-dropdown-menu>
<template is="dom-repeat" items="{{items}}" as="item" filter="{{computeFilter(searchString)}}" sort="_computeSort">
<div>[[item.__firebaseKey__]], [[item.order]]</div>
</template>
</template>
<script>
Polymer({
is: "my-element",
computeFilter: function(string) {
if (!string) {
// set filter to null to disable filtering
return null;
} else {
// return a filter function for the current search string
string = string.toLowerCase();
return function(item) {
var name = item.__firebaseKey__.toLowerCase();
var order = item.order.toLowerCase();
return (name.indexOf(string) != -1 ||
order.indexOf(string) != -1);
};
}
},
_computeSort: function(a, b) {
if (a.__firebaseKey__ == b.__firebaseKey__) {
return 0;
}
return a.__firebaseKey__ > b.__firebaseKey__ ? -1 : 1;
},
properties: {
items: {
type: Array
}
}
});
</script>
How do I sort the data in this jsBin by item.order
。
(Documentation)
<html>
<head>
<title>My Element</title>
<script data-require="polymer@*" data-semver="1.0.0" src="http://www.polymer-project.org/1.0/samples/components/webcomponentsjs/webcomponents-lite.js"></script>
<script data-require="polymer@*" data-semver="1.0.0" src="http://www.polymer-project.org/1.0/samples/components/polymer/polymer.html"></script>
<base href="http://element-party.xyz/" />
<link rel="import" href="all-elements.html" />
</head>
<body>
<dom-module id="my-element">
<template>
<firebase-collection location="https://dinosaur-facts.firebaseio.com/dinosaurs"
data="{{items}}"></firebase-collection>
<paper-input label="Search"
value="{{searchString::input}}"></paper-input>
<div>[[searchString]]</div>
<div>[[sortby]]</div>
<paper-dropdown-menu label="Sort by">
<paper-menu class="dropdown-content"
selected="{{sortby}}"
attr-for-selected="data-sortby">
<paper-item data-sortby="none" >None </paper-item>
<paper-item data-sortby="order">Order</paper-item>
</paper-menu>
</paper-dropdown-menu>
<template is="dom-repeat" items="{{items}}" as="item"
filter="{{computeFilter(searchString)}}"
sort="{{computeSort(sortby)}}">
<div>[[item.__firebaseKey__]], [[item.order]]</div>
</template>
</template>
<script>
Polymer({
is: "my-element",
computeFilter: function(string) {
if (!string) {
// set filter to null to disable filtering
return null;
} else {
// return a filter function for the current search string
string = string.toLowerCase();
return function(item) {
var name = item.__firebaseKey__.toLowerCase();
var order = item.order.toLowerCase();
return (name.indexOf(string) != -1 ||
order.indexOf(string) != -1);
};
}
},
computeSort: function(string) {
/* What function goes here? To sort by 'item.order' in reverse.
function(a, b) {
return b[string] - a[string];
}
*/
},
properties: {
items: {
type: Array
}
}
});
</script>
</dom-module>
<my-element></my-element>
</body>
</html>
您的排序未绑定到 属性,因此不需要花括号 {}
。
您需要将排序函数的格式设置为函数形式,该函数采用两个参数(每个参数对应一个要排序的值)并且 returns -1、1 或 0 基于以下规则:
- 如果 compareFunction(a, b) 小于 0,将 a 排序到比 b 低的索引,即 a 在前。
- 如果 compareFunction(a, b) returns 0,保持 a 和 b 彼此不变,但对所有不同元素进行排序。注意:ECMAscript 标准不保证这种行为,因此并非所有浏览器(例如至少可以追溯到 2003 年的 Mozilla 版本)都遵守这一点。
- 如果 compareFunction(a, b) 大于 0,则将 b 排序为比 a 低的索引。
有关详细信息,请参阅 Array.prototype.sort()
http://jsbin.com/zaxogonuxa/edit?html,output
<template>
<firebase-collection location="https://dinosaur-facts.firebaseio.com/dinosaurs" data="{{items}}"></firebase-collection>
<paper-input label="Search" value="{{searchString::input}}"></paper-input>
<div>[[searchString]]</div>
<div>[[sortby]]</div>
<paper-dropdown-menu label="Sort by">
<paper-menu class="dropdown-content" selected="{{sortby}}" attr-for-selected="data-sortby">
<paper-item data-sortby="none">None </paper-item>
<paper-item data-sortby="order">Order</paper-item>
</paper-menu>
</paper-dropdown-menu>
<template is="dom-repeat" items="{{items}}" as="item" filter="{{computeFilter(searchString)}}" sort="_computeSort">
<div>[[item.__firebaseKey__]], [[item.order]]</div>
</template>
</template>
<script>
Polymer({
is: "my-element",
computeFilter: function(string) {
if (!string) {
// set filter to null to disable filtering
return null;
} else {
// return a filter function for the current search string
string = string.toLowerCase();
return function(item) {
var name = item.__firebaseKey__.toLowerCase();
var order = item.order.toLowerCase();
return (name.indexOf(string) != -1 ||
order.indexOf(string) != -1);
};
}
},
_computeSort: function(a, b) {
if (a.__firebaseKey__ == b.__firebaseKey__) {
return 0;
}
return a.__firebaseKey__ > b.__firebaseKey__ ? -1 : 1;
},
properties: {
items: {
type: Array
}
}
});
</script>