Comments (4)
The API propery observer is:
propertyObserver(obj: object, propertyName: string): PropertyObserver;
It reads like this: for a given obj
, and a propertyName
, create a observer on obj
for that propertyName
.
So you can see that what we create is an observer of an object. It doesn't care if you threw that object away to replace it with something else. It only cares about its job: observe propertyName
property on object obj
.
Probably what you want is to use expression observer:
bindingEngine.expressionObserver(this, 'obj.p1').subscribe(newP1Value => {
// react to new value of this.obj.p1
});
Using expression observer above, you are observing the whole path specified in that expression, so replacing object will set up new observer properly for you.
from framework.
@ilsergente1993 thanks for filing this issue.
The behavior you experienced is the expected behavior. Observing an object does not and should not observe other objects. In your example, I would observe both obj
and its property for changes, so it would look like the following:
import { Disposable } from 'aurelia-framework'; // or 'aurelia-binding'
export class MyClass {
@bindable obj: object;
subscriptions: Disposable[];
objChanged(newObj) {
if (this.subscriptions) {
this.subscriptions.forEach(subscription => subscription.dispose());
this.subscriptions = undefined;
}
if (newObj) {
this.subscriptions = this.observeObj(newObj);
}
}
/**
* Return a list of disposables, each mapped to a subscription of corresponding property on a given obj
*/
observeObj(obj: object): Disposable[] {
return Object.keys(obj).forEach(propertyName => {
this.be.propertyObserver(obj, propertyName).subscribe((newValue, oldValue) => {
// do something with new value
});
});
}
}
from framework.
Thanks for the code @bigopon
I got your point to keep it flexible but, in my opinion, the framework should offer easy ways for common scenarios.
First of all, if I have an object with several properties, I expect one function to observe all the object properties, at least till the first nested level, that share the same callback, like:
this.be.propertyObserver(obj).subscribe((newValue, oldValue) => {
// do something with new value
});
and this can return the array of subscriptions or
propertyObserver(obj: Object, propertyName: string | string[]): PropertyObserver | PropertyObserver[];
as I wrote before.
Then, actually, I don't understand why this this.obj = { p1: "asd", p2: 10, p3: true };
should not fire the callback and should break the observing system. If I observe only p1
of obj
, doing this.obj = { p1: "asd", p2: 10, p3: true };
I actually change p1
property value.
So why shouldn't it fire the callback?
Thanks for the explanation 😄
from framework.
It reads like this: for a given obj, and a propertyName, create a observer on obj for that propertyName.
Now I got it, thanks for the explanation @bigopon
And the expression observer now has a reason to be there 😄
Again, thanks
from framework.
Related Issues (20)
- Many aurelia libraries are broken in iOS 16 HOT 47
- example link for codesandbox in README.md HOT 1
- Can somebody update dependencies, please? HOT 3
- How to bind repeat.for on the async array variable? HOT 5
- aurelia.use.developmentLogging(environment.debug ? 'debug' : 'warn'); is broken? HOT 5
- Building all public files to www folder
- Issue with compose element and composition
- Combination of `@dynamicOptions` and `primaryProperty` HOT 5
- Publish Aurelia project with visual studio 2017. HOT 1
- Allow better typing for module configuration HOT 4
- Upgrade gulp to v4.
- Staging a component for testing
- UI is not re-rendered when Set is used. HOT 5
- Binding Engine seems to strip CR from text HOT 1
- Component inheritance with bindings on the base doesn't work as expected
- Content of repeat for on tr tag rendered outside of tag HOT 1
- How to use aurelia in qiankun HOT 2
- Content editable div inside a parent div that has a mousedown event on it cannot be edited in Aurelia HOT 1
- npm audit warning for aurelia-framework - XSS vulnerability in default HTML sanitizer implementation HOT 15
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from framework.