Comments (5)
Both clone()
and the getters were contributions. Help me with a pull request or give me some time. :-)
from ltx.
I actually tried fixing it myself, but I must be missing a key element in Javascript. I'm a long-time C++ guy and quite new to Javascript so I know there's a LOT I don't know. :-)
I tried basically at the top-level of the element doing something like:
for (k in el.attrs)
el[k] = el.attrs.k;
this did produce the getters, but it basically made a 'duplicate' of the .attrs rather than a link to them. Subsequent accesses of:
el.type = 'set';
This would change el.type, but it would not change el.attrs.type and so it becomes broken. I realize this is a Javascript misunderstanding, and so if you're looking for a pull request from me, I'll need you to give me a hint as to what to study in order to make that property-link appropriately so that I can fix it the right way. :)
from ltx.
Could you please write a few tests for this problem?
from ltx.
Hey there. Ok - so I think I'm losing my mind...here's my test. But unfortunately the failure is not what I anticipated. I know for a certainty that I had a LOT of code (and I can look through my own repo to prove this) which accessed directly:
stanza.to
rather than
stanza.attrs.to
and it worked in my code...maybe because I was receiving the stanza rather than simply generating one directly using new ltx.Element() ? So, the following snippet was supposed to demonstrate that .to works in the original version but after cloning, the .to should fail with undefined. But both are undefined. Sigh.
var ltx = require('ltx')
var orig = new ltx.Element('message', {to: '[email protected]', type: 'chat'})
.c('x', {xmlns: 'http://jabber.org/protocol/muc'});
console.log("orig: attrs.to: " + orig.root().attrs.to + " - orig: .to: " + orig.root().to);
var cln = orig.root().clone();
console.log("cln: attrs.to: " + cln.root().attrs.to + " - cln: .to: " + cln.root().to);
from ltx.
Closing due to inactivity. If this still needs discussion please reopen. Cheers, Lloyd.
from ltx.
Related Issues (20)
- Unable to parse xml with multiline comment HOT 4
- Unexpected token '>' when running uglifyJS HOT 4
- Missing `end` event, ltx parser. HOT 3
- stricter LtxParser HOT 1
- version 3.0.0 HOT 1
- tagString should ignore `null/undefined` substitutions
- toString() function encodes XML escape characters by default HOT 5
- How to send HTML formatted message? HOT 9
- Dead Docs link in README HOT 3
- Performance improvement HOT 4
- Uglify Js error on version 2.7.2 HOT 2
- PR #126 should have been in 3.0 HOT 2
- XML conversion to DOM and then back to XML removes comment HOT 1
- CDATA bug HOT 3
- clone should preserve the xmlns if it is set on the parent HOT 1
- `ltx.stringify` should escape XML specific chars correctly HOT 2
- Move away from vows
- Documentation?
- Error when importing CommonJS module
- Removal of toJSON should be a major version upgrade? HOT 3
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 ltx.