JavaScript UI Libraries & Blazor Components Suite – Smart UI › Forums › Window › Dynamic content
Tagged: angular window, custom element, custom window content, react window, smart elements, smart framework, web component, web components, window content
- This topic has 6 replies, 2 voices, and was last updated 4 years, 4 months ago by tundekeller94.
-
AuthorPosts
-
May 8, 2020 at 3:10 pm #100740tundekeller94Member
Can the content of the window be assigned/added through JavaScript?
May 11, 2020 at 8:25 am #100742HristoforMemberHi Tünde Keller,
Yes, the content of the window element can be changed dynamically via JS in severall ways:
1)innerHTML
– settinginnerHTML
directly on the Window instance, for example:
document.querySelector('smart-window').innerHTML = 'new content';
2)appendChild(), removeChild()
methods – using these methods you can append or remove HTML elements to the Window content section, for example:
document.querySelector('smart-window').appendChild(document.createElement('div'));
Furthermore, the content of the Window can be cleared usinginnerHTML
or theclear()
methods. See the official Window API for additional information.
Best Regards,
Christopher
Smart HTML Elements Team
https://www.htmlelements.comMay 11, 2020 at 10:29 am #100743tundekeller94MemberThanks, that worked great!
Is it also possible to define where the element is positioned that I’m adding? Normally a position: absolute with left and right attributes should do the trick, but when I try to apply those attributes/properties to an element and I append that element to the window, it just positions the element to the top center.May 11, 2020 at 11:25 am #100745HristoforMemberHi Tünde Keller,
You can append a container withposition: relative;
and place your desired HTML elements inside it and position them anywhere you want. For example:cosnt window = document.querySelector('smart-window'); window.innerHTML = '<div id="myContainer"><div id="someElement">Your content goes here</div></div>';
CSS:
#myContainer { width: 100%; height:100%; position: relative; } #myContainer someElement { position: absolute; top: 50%; left: 50%; }
Best Regards,
Christopher
Smart HTML Elements Team
https://www.htmlelements.comMay 11, 2020 at 1:05 pm #100747tundekeller94MemberHi Christopher,
Can I do that without external CSS?
I mean if I do this:
<smart-window>
<button style=”position: absolute; left: 20px; top: 60px;”>Hello</button>
</smart-window>
Then the button has the position applied. I’d like to do the same with document.createElement() and windowComponent.appendChild().May 12, 2020 at 6:13 am #100749HristoforMemberHi Tünde Keller,
You can do without the additional container and CSS but it will be harder for you without it, because you have to take in considuration that you have a header above the content section of the window.
Best Regards,
Christopher
jQWidgets Team
http://www.jqwidgets.comMay 12, 2020 at 7:49 am #100750tundekeller94MemberHi Christopher,
The header size is not a problem in my case. Thanks for confirming, I found where the issue was (unrelated to Smart HTML Elements). -
AuthorPosts
- You must be logged in to reply to this topic.