What is the best way to access Document
and Window
objects in ES6
/ Aurelia
framework? I did try accessing window
directly in my Aurelia code and it does seem to work, but is that the proper way or is there an Aurelia/ES6 way of doing that?
Specifically, I want to access properties like window.localStorage and window.sessionStorage. I'm just starting with Aurelia and ES6, so I'm a little noob on how to do this one though I would like to follow the standards.
Something like the following:
constructor() {
this.user = JSON.parse(window.sessionStorage.user || window.localStorage.user);
}
That code actually work in Aurelia, but is that correct to write it this way?
Right-click on the Start button and go to Settings > Apps > Manage optional features > Add feature. Now select RSAT: Active Directory Domain Services and Lightweight Directory Tools. Finally, select Install then go to Start > Windows Administrative Tools to access Active Directory once the installation is complete.
Use Task View to show all windows on the same screen. You can also open Task View by pressing Windows key + Tab. If you don't see the Task View icon on the taskbar, right-click the Taskbar, select Taskbar settings, and then click the switch next to "Task View" to turn it on.
In the search box next to Start on the taskbar, type control panel. Select Control Panel from the list of results. Note: Many Control Panel features are simpler and faster in Settings .
Press the Win + R keys on your keyboard, to open the Run window. Then, type "services. msc" and hit Enter or press OK. The Services app window is now open.
That is the correct way to do it in Aurelia when working with Web APIs, so you're fine with the code you currently have.
However, when working with the DOM you can of course use the standard DOM API as well, but Aurelia has a Platform Abstraction Layer (PAL docs) that will abstract whatever platform your application resides on with a DOM-like API.
For example, the equivalent of document.getElementById
would be
import {inject} from 'aurelia-framework'
import {DOM} from 'aurelia-pal'
@inject(DOM)
export class Home {
constructor(DOM) {
this.DOM = DOM
}
attached() {
let element = this.DOM.getElementById('someId')
}
}
Unfortunately, PAL isn't really doing much at the moment but in the future it is planned to allow you to work with your everyday DOM API calls even though your application may not be running in a "normal" DOM.
One very important thing not to forget is that the native DOM & Web APIs are really powerful and there is nothing wrong with using their native implementations. Other frameworks tend to build their own implementation around the Web API's that is tailored to their frameworks' structures and best-practices but that is not necessarily the best thing.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With