使用Aurelia的ref属性

时间:2015-10-12 16:17:08

标签: javascript aurelia aurelia-binding

Aurelia提供了ref attribute,其中包括应该能够提供对自定义元素的视图模型的引用。

我试图构建一个示例,其中一个文本框(生产者)的值通过管道传输到另一个只读文本框(使用者)。

正如所料:

  • 键入生产者文本框,调用producerInput,设置新值。
  • producerOutput被重复轮询,因为应该更新对consumerInput的绑定。
  • consumerOutput被重复轮询,因为应该更新对消费者文本框的绑定。

consumerInput未被调用。如果我理解正确的话,应该在每次调用producerOutput后调用它。 consumerInput未被调用意味着该值不会通过管道传递到消费者文本框。为什么没有consumerInput被调用,我该如何解决?

ref.html

<template>

    <require from="producer"></require>
    <require from="consumer"></require>

    <producer producer.ref="producerViewModel"></producer>
    <consumer consumerInput.bind="producerViewModel.producerOutput"></consumer>

</template>

ref.js

export class Ref {

}

producer.html

<template>
    <div>
        producer: <input value.bind="producerInput" />
    </div>
</template>

producer.js

import {customElement} from 'aurelia-framework';

@customElement('producer')
export class Producer {

    set producerInput(v) {
        this.value = v;
    }

    get producerOutput() {
        return this.value;
    }

}

consumer.html

<template>
    <div>
        consumer: <input value.bind="consumerOutput" readonly />
    </div>
</template>

consumer.js

import {customElement, bindable} from 'aurelia-framework';

@customElement('consumer')
@bindable('consumerInput')
export class Consumer { 

    set consumerInput(v) {
        this.value = v;
    }

    get consumerOutput() {
        return this.value;
    }

}

更新了工作解决方案:

ref.html:

<template>

    <require from="producer"></require>
    <require from="consumer"></require>

    <producer producer.ref="producerViewModel"></producer>
    <consumer input.bind="producerViewModel.output"></consumer>

</template>

ref.js

export class Ref {

}

producer.html

<template>
    <div>
        producer: <input value.bind="output" />
    </div>
</template>

producer.js

import {bindable} from 'aurelia-framework';

export class Producer {

    @bindable output;

}

consumer.html

<template>
    <div>
        consumer: <input value.bind="input" readonly />
    </div>
</template>

consumer.js

import {bindable} from 'aurelia-framework';

export class Consumer { 

    @bindable input;

}

1 个答案:

答案 0 :(得分:3)

DOM会自动降低所有属性。您无法使用consumerInputproducerOutput作为可绑定的属性名称。 Aurelia使用一种约定连接具有混合外壳的可绑定属性名称的约定。

例如,class MyElement { @bindable fooBar }将像这样使用:

<my-element foo-bar.bind="baz"></my-element>

试试这个:

import {customElement, bindable} from 'aurelia-framework';

@customElement('consumer')
export class Consumer { 
    @bindable input;

    inputChanged(newValue, oldValue) {
      // aurelia will call this automatically- a convention looks for methods on the vm that match bindable property names.
    }
}

生产者自定义元素需要进行类似的更改。