- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
从我对 Flex 的一点经验中,我了解了可绑定(bind)变量,例如,这样文本元素的内容会随着变量的值而改变。
我想知道是否可以在 JavaScript 中做这样的事情。例如,假设我有一个 <h1 id="big_title">
我想包含文档的标题。这可以很容易地用 document.getElementById('big_title').innerHTML = document.title;
完成。 ,但是如果document.title
怎么办?变化?我必须手动更新 big_title
换一种说法,有没有一种方法可以创建自定义 onchange
- 像变量而不是 DOM 元素上的事件处理程序?此处理程序可以根据需要更新标题。
编辑:我知道我可以使用 setInterval
检查变量“绑定(bind)”(在数组中定义)并根据需要进行更新,但这会有些 hack-ish 并且需要在响应性和对性能的影响之间做出折衷。
最佳答案
您可以在大多数主流浏览器中“观察”对象。 Here是垫片。这个想法本质上是有一个 setter (在那个例子中它是名为 handler
的函数),当值改变时将执行它。我不确定浏览器支持的程度。
虽然老实说,拥有自己的 setter 方法听起来更容易。要么把它变成一个对象(你可以很容易地扩展这个例子来使用一个通用的 handler
insetad 总是改变标题):
function Watchable(val) { // non-prototypal modelling to ensure privacy
this.set = function(v){
document.title=val=v;
};
this.get = function(){return val;};
this.set(val);
}
var title = new Watchable("original title");
title.get(); // "original title"
title.set("second title"); // "second title"
title.get(); // "second title"
或者如果它不是您需要多次实例化的东西,一个简单的函数+约定就可以了:
function changeVal(newVal) {
variableToWatch = newVal;
// change some DOM content
}
关于javascript - JavaScript 中的 "Bindable"变量?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7543710/
我发现当我为它定义一个@bindable 属性和一个 propertyChanged 处理程序时,它有时会在自定义组件的 bind() 方法之前被调用,有时则不会。 https://gist.run/
我正在创建一个具有 ContentView 的控件(源自 Frame ) field : public class SelectionFrame : ContentView { Frame f
我开始学习 Aurelia,我正在关注 Getting Started他们网站上的指南,但我使用的是 Typescript 而不是 Javascript。一切都很好,但我在使 @bindable 装饰
我遇到了一些奇怪的事情,但也许其他人以前遇到过。 我有一个基类,它不扩展任何东西。让我们称之为... public class FooBar { //... } 但我想绑定(bind)它暴露的
意义 。 . .我见过将组件绑定(bind)到 [Bindable] dataProvider 的案例。当我更新 dataProvider 中的数据时,组件不会立即反射(reflect)更改。我需要做
[Bindable] /** * Display output of video device. */ public var videoLocal : Video; 有谁知道
我正在使用数据绑定(bind)库通过方法使用属性 setter 来更新 TextView 的可见性 TextView : 和可绑定(bind) View 模型方法“kalase”: @Bindabl
我是数据绑定(bind)的新手,这是我的代码,但我在构建时遇到了这个错误 class DatabindingViewModel :ViewModel() { val currentFruitName:
从我对 Flex 的一点经验中,我了解了可绑定(bind)变量,例如,这样文本元素的内容会随着变量的值而改变。 我想知道是否可以在 JavaScript 中做这样的事情。例如,假设我有一个 我想包含文
我将 aurelia 与 TypeScript (v 1.5.4) 结合使用。我正在使用 https://github.com/aurelia/<>/blob/master/dist/amd/aure
我正在努力理解当 Bindable 对象发生更改时如何运行方法。这是我到目前为止的代码: 但是,由于某种原因, fetchFoods 方法永远不会因为 searchText 更改而被调用,我似乎无法理
我需要编写一个看起来像 TextBox 的自定义控件,它包含一个名为 Refresh() 的方法,其主要目的是清除文本并回滚一些其他值。 该方法应以某种方式变得可绑定(bind),以便其他人可以将其
代码: App.js export class App { constructor() { this.widgets = [{ name: 'zero'}, {name: 'one'},
我是 android 数据绑定(bind)的新手,我正在查看代码,如下所示 @get:Bindable var userIds: MutableList = mutableListOf()
在 Xamarin Forms 中,我试图创建一个带有属性的 xaml 转换器。 这将用于,例如,基于隐藏属性的代码以不同方式显示列表中的值。 我的代码基于此:https://stackoverflo
可绑定(bind) LINQ 和连续 LINQ 之间的主要区别是什么? •可绑定(bind)LINQ:www.codeplex.com/bindablelinq • 连续 LINQ:www.codep
绑定(bind)不适用于图像标记。当我调试时,我看到Extension类中Source的值始终为null?但标签的内容不为空。 Xaml 图像资源扩展 // You exclude the 'Ex
问题已解决,见下文 问题 我在 Flex Builder 3 中工作,我有两个 ActionScript 3 类(ABC 和 XYZ)和一个 Flex MXML 项目(main.mxml)。我有一个
我继承了一个 Adobe AIR 应用程序,并试图通过 Flash Builder 4.5 对其进行调试。在 Flash Builder 中,当我查看其中一个 MXML 文件时,我看到每次使用 [
我试图将过滤器数组传递给多个 View ,但过滤不起作用。如果我删除过滤器,您可以将数组传递给下一个 View ,但这会在 ForEach 循环期间导致另一个错误。我已经在下面发布了所有代码。 有谁知
我是一名优秀的程序员,十分优秀!