The Essential JS 2 for JavaScript (global script) is an ES5 formatted pure JavaScript framework which can be directly used in latest web browsers.
Create an app folder myapp
in local machine to initialize Essential JS 2 JavaScript components.
Using either of the following way to refer the required script and styles.
Step 1: You can get the global scripts and styles from the Essential Studio JavaScript (Essential JS 2) build installed location.
Step 2: To render Sidebar component, need to add Sidebar and its dependent packages from below installed location.
Syntax:
package:
**(installed location)**/Syncfusion/Essential Studio/{RELEASE_VERSION}/Essential JS 2/{PACKAGE_NAME}
Example:
Package:
C:/Program Files (x86)/Syncfusion/Essential Studio/15.4.30/Essential JS 2/ej2-base
packages:
C:/Program Files (x86)/Syncfusion/Essential Studio/15.4.30/Essential JS 2/ej2-navigations
Step 3: Create a folder myapp/resources
and copy/paste the above mentioned packages from the above installed location to myapp/resources
location.
Step 4: Create a HTML page (index.html) in myapp
location and add the Essentials JS 2 script and style references.
<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title>Essential JS 2</title>
<!-- Sidebar and its dependent theme -->
<link href="resources/ej2-base/styles/material.css" rel="stylesheet" type="text/css"/>
<link href="resources/ej2-navigations/styles/material.css" rel="stylesheet" type="text/css"/>
<!-- Essential JS 2 Sidebar's global script -->
<script src="resources/ej2-navigations/dist/global/ej2-navigations.min.js" type="text/javascript"></script>
</head>
<body>
</body>
</html>
Note: If you want to refer the combined component styles, please make use of our CRG
(Custom Resource Generator) in your application.
Step 5: Now, add the div
element and initiate the Essential JS 2 Sidebar
component in the index.html
by using following code
<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title>Essential JS 2</title>
<!-- Sidebar and its dependent theme -->
<link href="resources/ej2-base/styles/material.css" rel="stylesheet" type="text/css" />
<link href="resources/ej2-navigations/styles/material.css" rel="stylesheet" type="text/css" />
<!-- Essential JS 2 Sidebar's global script -->
<script src="resources/ej2-navigations/dist/global/ej2-navigations.min.js" type="text/javascript"></script>
</head>
<body>
<!-- Add the HTML <div> element -->
<div id='container'>
<aside id="default">
<div class="title"> Sidebar </div>
</aside>
<!-- end of sidebar element -->
<!-- main content declaration -->
<div>
<div class="title">Main content</div>
<div class="sub-title"> Content goes here</div>
</div>
</div>
<script>
// initialize Sidebar component
var defaultSidebar = new ej.navigations.Sidebar();
// Render initialized sidebar.
defaultSidebar.appendTo('#default')
</script>
</body>
</html>
Step 6: Now, run the index.html
in web browser, it will render the Essential JS 2 Sidebar component.
Step 1: The Essential JS 2 components scripts and styles are already hosted in the below CDN link formats.
Syntax:
Script:
http://cdn.syncfusion.com/ej2/21.1.35/{PACKAGE_NAME}/dist/global/{PACKAGE_NAME}.min.js
Style:
http://cdn.syncfusion.com/ej2/21.1.35/{PACKAGE_NAME}/styles/material.css
Example:
Script:
http://cdn.syncfusion.com/ej2/21.1.35/ej2-navigations/dist/global/ej2-navigations.min.js
Styles:
http://cdn.syncfusion.com/ej2/21.1.35/ej2-navigations/styles/material.css
Step 2: Have to add CDN
global script and style for calender and its dependent packages in myapp/index.html
like below.
<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title>Essential JS 2 Sidebar Component</title>
<!-- Sidebar and its dependent theme -->
<link href="http://cdn.syncfusion.com/ej2/21.1.35/ej2-base/styles/material.css" rel="stylesheet" type="text/css" />
<link href="http://cdn.syncfusion.com/ej2/21.1.35/ej2-navigations/styles/material.css" rel="stylesheet" type="text/css" />
<!-- Essential JS 2 Sidebar's global script -->
<script src="http://cdn.syncfusion.com/ej2/21.1.35/ej2-navigations/dist/global/ej2-navigations.min.js" type="text/javascript"></script>
</head>
<body>
<!-- Add the HTML <div> element -->
<div id='container'>
<aside id="default">
<div class="title"> Sidebar </div>
</aside>
<!-- end of sidebar element -->
<!-- main content declaration -->
<div>
<div class="title">Main content</div>
<div class="sub-title"> Content goes here</div>
</div>
</div>
<script>
// initialize Sidebar component
var defaultSidebar = new ej.navigations.Sidebar();
// Render initialized sidebar.
defaultSidebar.appendTo('#default')
</script>
</body>
</html>
When referencing CDN links in application, always ensure the network connection will be in enabled state.
Enabling the showBackdrop
in the Sidebar component will prevent
the main content from user interactions, when it is in expanded state.
Here, the DOM elements will not get changed. It only closes the main content by covering with a black backdrop overlay and focuses the Sidebar in the screen.
ej.base.enableRipple(true);
//sidebar initialization
var defaultSidebar = new ej.navigations.Sidebar({
showBackdrop: true,
type: "Push",
width: '280px'
});
defaultSidebar.appendTo('#default-sidebar');
//end of sidebar initialization
// Toggle(Open/Close) the sidebar
document.getElementById('toggle').onclick = function() {
defaultSidebar.toggle();
};
// Close the sidebar
document.getElementById('close').onclick = function() {
defaultSidebar.hide();
};
//end of sidebar initialization
// Toggle(Open/Close) the sidebar
<!DOCTYPE html><html lang="en"><head>
<title>Essential JS 2 Sidebar</title>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta name="description" content="Typescript UI Controls">
<meta name="author" content="Syncfusion">
<link href="https://maxcdn.bootstrapcdn.com/bootstrap/4.0.0-beta.3/css/bootstrap.min.css" rel="stylesheet">
<link href="//cdn.syncfusion.com/ej2/21.1.35/ej2-base/styles/material.css" rel="stylesheet">
<link href="//cdn.syncfusion.com/ej2/21.1.35/ej2-buttons/styles/material.css" rel="stylesheet">
<link href="//cdn.syncfusion.com/ej2/21.1.35/ej2-lists/styles/material.css" rel="stylesheet">
<link href="//cdn.syncfusion.com/ej2/21.1.35/ej2-navigations/styles/material.css" rel="stylesheet">
<link href="styles.css" rel="stylesheet">
<script src="https://cdn.syncfusion.com/ej2/21.1.35/dist/ej2.min.js" type="text/javascript"></script>
</head>
<body>
<div id="container">
<!-- sidebar element declaration-->
<aside id="default-sidebar">
<div class="title"> Sidebar content</div>
<div class="sub-title">
Click the button to close the Sidebar.
</div>
<div class="center-align">
<button id="close" class="e-btn close-btn">Close Sidebar</button>
</div>
</aside>
<!-- end of sidebar element -->
<!-- main content declaration -->
<div>
<div class="title">Main content</div>
<div class="sub-title"> Click the button to open/close the Sidebar.</div>
<div style="padding:20px" class="center-align">
<button id="toggle" class="e-btn e-info">Toggle Sidebar</button>
</div>
</div>
<!--end of main content -->
</div>
<script>
var ele = document.getElementById('container');
if(ele) {
ele.style.visibility = "visible";
}
</script>
<script src="index.js" type="text/javascript"></script>
</body></html>
Positioning the Sidebar to the right or left of the main content can be achieved by using the position
property. If the position is not set, the Sidebar will expand from the left to the body element.
ej.base.enableRipple(true);
//sidebar initialization
var defaultSidebar = new ej.navigations.Sidebar({
showBackdrop: true,
enablePersistence:true,
type: "Push",
width: '280px'
});
defaultSidebar.appendTo('#default-sidebar');
//end of Sidebar initialization
//toggle button initialization
var togglebtn = new ej.buttons.Button({iconCss: 'e-icons burg-icon', isToggle: true, content:'Open'}, '#toggle');
//Click Event for toggle button to triger show/hide methods of Sidebar
document.getElementById('toggle').onclick = function(){
if (document.getElementById('toggle').classList.contains('e-active')) {
togglebtn.content = 'Close';
defaultSidebar.show();
} else {
togglebtn.content = 'Open';
defaultSidebar.hide();
}
};
// Close the sidebar
document.getElementById('close').onclick = function() {
defaultSidebar.hide();
document.getElementById('toggle').classList.remove('e-active');
togglebtn.content = 'Open'
};
var positionLeft = new ej.buttons.RadioButton({ label: 'Left', name: 'state', checked: true,change:Change });
positionLeft.appendTo('#left');
//unchecked state
var positionRight = new ej.buttons.RadioButton({ label: 'Right', name: 'state',change:Change });
positionRight.appendTo('#right');
//change the position of the Sidebars
function Change(args){
defaultSidebar.position = (args.event.target.id == "left") ? "Left" : "Right";
}
<!DOCTYPE html><html lang="en"><head>
<title>Essential JS 2 Sidebar</title>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta name="description" content="Typescript UI Controls">
<meta name="author" content="Syncfusion">
<link href="https://maxcdn.bootstrapcdn.com/bootstrap/4.0.0-beta.3/css/bootstrap.min.css" rel="stylesheet">
<link href="//cdn.syncfusion.com/ej2/21.1.35/ej2-base/styles/material.css" rel="stylesheet">
<link href="//cdn.syncfusion.com/ej2/21.1.35/ej2-buttons/styles/material.css" rel="stylesheet">
<link href="//cdn.syncfusion.com/ej2/21.1.35/ej2-navigations/styles/material.css" rel="stylesheet">
<link href="styles.css" rel="stylesheet">
<script src="https://cdn.syncfusion.com/ej2/21.1.35/dist/ej2.min.js" type="text/javascript"></script>
</head>
<body>
<div id="container">
<!-- sidebar element declaration -->
<aside id="default-sidebar">
<div class="title"> Sidebar content</div>
<div id="list"></div>
<div class="sub-title">
Click the button to close the Sidebar.
</div>
<div class="center-align">
<button id="close" class="e-btn close-btn">Close Sidebar</button>
</div>
</aside>
<!-- end of sidebar element -->
<!-- main content declaration -->
<div id="head">
<button id="toggle" class="e-btn e-info"></button>
</div>
<div class="maincontent" style="height:335px;border:1px solid gray">
<div>
<div class="title">Main content</div>
<div class="sub-title">
<div class="radiobutton">
<input type="radio" id="left">
</div>
<div class="radiobutton">
<input type="radio" id="right">
</div>
</div>
</div>
</div>
<!-- end of main content declaration -->
</div>
<script>
var ele = document.getElementById('container');
if(ele) {
ele.style.visibility = "visible";
}
</script>
<script src="index.js" type="text/javascript"></script>
</body></html>