Как передать произвольные данные в функцию обработчика событий кликов из веб-компонента Dart-полимера
В Dart Web UI можно было передавать произвольные данные для работы в ответ на события, например, следующий фрагмент передает значение 2
методу increment(int incBy)
в ответ на событие нажатия кнопки:
<!-- Web UI -->
<element name="x-click-counter">
<template>
<button on-click="increment(2)"> <!-- passing a value of 2 -->
Click me
</button>
</template>
</element>
<script>
import 'package:web_ui/web_ui.dart';
class CounterComponent extends WebComponent {
void increment(int incBy) { // accept the value of 2
count = count + incBy;
}
}
</script>
В Polymer (и Polymer.dart) атрибут события on-click требует строковой версии имени функции, а не фактического вызова функции. Это описано на странице :
Значение атрибута обработчика события - это имя строки метода на компоненте. В отличие от традиционного синтаксиса, вы не можете ставить исполняемый файл кода в атрибуте.
Используя параметр polymer.dart, это выглядит так:
<polymer-element name="x-click-counter">
<template>
<button on-click="increment"> <!-- can't pass a value of 2, as you need to pass a string -->
Click Me
</button>
</template>
</polymer-element>
<script>
import 'package:polymer/polymer.dart';
@CustomTag("x-click-counter")
class CounterComponent extends PolymerElement with ObservableMixin {
@observable int count = 0;
void increment(Event event, var detail, var target) { // How do I pass 2 to this function?
count = count ++;
}
}
</script>
Вопрос: Как передать произвольное значение функции increment
?
Ответы
Ответ 1
Вы можете использовать атрибуты html data-
для передачи дополнительных данных, а затем обращаться к ним через параметр target
.
Повторяя пример полимера, чтобы добавить поле data-incby
, которое принимает значение, увеличивающее счет, выглядит следующим образом:
<polymer-element name="x-click-counter">
<template>
<button on-click="increment" data-incby="2"> <!-- now passing the value as a data attribute -->
Click Me
</button>
</template>
</polymer-element>
<script>
import 'package:polymer/polymer.dart';
@CustomTag("x-click-counter")
class CounterComponent extends PolymerElement with ObservableMixin {
@observable int count = 0;
void increment(Event event, var detail, var target) {
int incBy = int.parse(target.attributes['data-incby']); // extract the value 2
count = count + incBy;
}
}
</script>
Ответ 2
Dart и Polymer.dart изменились после ответа Криса. Вот обновленный код для Dart v1.0:
<polymer-element name="x-click-counter">
<template>
<button on-click="{{increment}}" data-incby="2"> <!-- now passing the value as a data attribute -->
Click Me
</button>
<span>{{count}}</span>
</template>
</polymer-element>
<script type="application/dart">
import 'package:polymer/polymer.dart';
import 'dart:html';
@CustomTag("x-click-counter")
class CounterComponent extends PolymerElement {
@observable int count = 0;
CounterComponent.created() : super.created();
void increment(Event event, var detail, var target) {
int incBy = int.parse(target.attributes['data-incby']); // extract the value 2
count = count + incBy;
}
}
</script>
Ответ 3
Мое решение для полимера 0.11.0 + 5
element.html
<link rel="import" href="../packages/polymer/polymer.html">
<polymer-element name="dp-element">
<template>
<div class="row">
<ul>
<template repeat="{{ item in items }}">
<li on-click="{{load}}" data-incby="{{item}}">{{ item }}</li>
</template>
</ul>
</template>
<script type="application/dart">
import 'package:polymer/polymer.dart';
import 'view.dart';
import 'dart:html';
@CustomTag('dp-element')
class DpElement extends PolymerElement {
@observable List<String> items;
DpElement.created() : super.created(){
}
void load(Event event, var detail, var target) {
String incBy = target.attributes['data-incby'];
print(incBy);
}
}