can-element/attributes
Sets up attribute bindings when using can-define.
Object
Use
To use this can-define behavior just import it. For any defined property on the element, you can specify attribute: true
and the property will be two-way bound to the attribute. Any change in either will update the other.
Since the type can still be specified, you can have properties which are typed even though the attribute will always be a string.
var define = require("can-define");
var Element = require("can-element").Element;
var view = require("./calc.stache");
var defineAttr = require("can-element/attributes");
var Calculator = class extends Element {
static get view() {
return view;
}
};
define(Calculator.prototype, {
num: {
type: "number",
attribute: true
}
});
defineAttr(Calculator);
customElements.define("my-calculator", Calculator);
var el = new Calculator();
el.setAttribute("num", "34");
el.num; // -> 34