# Getting Started with JavaScript in the Low-Code Approach
> data:image/s3,"s3://crabby-images/3861d/3861d95116899bff267c2f757fafba2b0eda5cc0" alt="icon-note.gif" **NOTE**
This feature will be available in DevEco Studio V2.2 Beta1 and later versions.
>
> For best possible results, use [DevEco Studio V3.0.0.900 Beta3](https://developer.harmonyos.com/cn/develop/deveco-studio#download_beta_openharmony) for your development.
On the OpenHarmony low-code development pages, you can design your app UI in an efficient, intuitive manner, with a wide array of UI editing features.
You can develop applications or services in the low-code approach using either of the following methods:
- Create a project that supports low-code development. This method is used as an example in this topic.
- In an existing project, create a Visual file for development.
## Creating a Project That Supports Low-Code Development
> data:image/s3,"s3://crabby-images/3861d/3861d95116899bff267c2f757fafba2b0eda5cc0" alt="icon-note.gif" **NOTE**
This feature is available in DevEco Studio 3.0 Beta2 and later versions and works with compileSdkVersion 7 or later.
>
1. In DevEco Studio, if no project is open, click **Create Project**; if a project is already open, choose **File** > **New** > **Create Project**. Then, select **Empty Ability** and click **Next**.
data:image/s3,"s3://crabby-images/6288b/6288bbbbe7f095de9b218ceb388073981bc074b5" alt="en-us_image_0000001268198893"
2. Go to the project configuration page, select **Enable Super Visual**, set **UI Syntax** to **JS**, and retain the default values for other parameters.
data:image/s3,"s3://crabby-images/5a259/5a2594b4ba4a62b9a28cfb48667bc72d36a1e9d5" alt="en-us_image_0000001223717294"
3. Click **Finish**. DevEco Studio will automatically generate the sample code and resources that match your project type. Wait until the project is created.
## Low-code Project Files
After the project synchronization is complete, a low-code directory structure is automatically generated in the project, as shown below.
data:image/s3,"s3://crabby-images/e26da/e26da36b08d0c6353b685d0ee6800f239d06697d" alt="en-us_image_0000001223558810"
- **entry > src > main > js > MainAbility > pages > index > index.js** : defines logical relationships, such as data and events, used on low-code pages. For details, see [JavaScript](../ui/js-framework-syntax-js.md). If multiple low-code development pages are created, a page folder and the corresponding **.js** file will be created for each of these pages.
> data:image/s3,"s3://crabby-images/3861d/3861d95116899bff267c2f757fafba2b0eda5cc0" alt="icon-note.gif" **NOTE**
To avoid build errors when using the low-code development page, make sure the directory where the corresponding **.js** file is located does not contain **.hml** or **.css** files. For example, in the preceding example, no **.hml** or **.css** file is allowed in **js** > **MainAbility** > **pages** > **index**.
>
- **entry > src > main > supervisual > MainAbility > pages > index > index.visual** : stores the data model of the low-code development page. You can double-click the file to open the low-code development page. If multiple low-code development pages are created, a page folder and the corresponding **.visual** file will be created for each of these pages.
## Building the First Page
After the project synchronization is complete, the default first page contains the **Div** and **Text** (**Hello World**) components. To better understand low-code development, we'll delete these template components from the canvas and set the page from scratch.
Add **Div**, **Text**, and **Button** components to the first page.
1. Delete the existing template components from the canvas.
Open the index.visual file, right-click the existing template components on the canvas, and choose **Delete** from the shortcut menu to delete them. Below is an illustration of the operations.
data:image/s3,"s3://crabby-images/fc0d1/fc0d1490344abcfd19bd9f016da740d457c32321" alt="en-us_image_0000001216600980"
2. Add a **Div** component and set its styles and attributes.
Drag the **Div** component from the **UI Control** area to the canvas. In the **Attributes & Styles** area on the right, click data:image/s3,"s3://crabby-images/0541d/0541d5feddeb22b2d2ace7b290e0e2b425b55023" alt="en-us_image_0000001260226691"**General** and set **Height** to **100%** so that the component fills the entire screen. Click data:image/s3,"s3://crabby-images/f03c8/f03c84ef3225aa3ba7ba8b4b8945e6980fdfe7d7" alt="en-us_image_0000001215226858"**Flex**, set **FlexDirection** to **column** so that the main axis of the component is vertical, and set both **JustifyContent** and **AlignItems** to **center** so that the child components of the **Div** component are centered along the main axis and cross axis. Below is an illustration of the operations.
data:image/s3,"s3://crabby-images/35ffc/35ffc5621bcd38679339a06e2165754803fb6323" alt="en-us_image_0000001216448880"
3. Add a **Text** component.
Drag the **Text** component from the **UI Control** area to the center area of the **Div** component. In the **Attributes & Styles** area, click data:image/s3,"s3://crabby-images/721a5/721a5ac377bb61f67e68bcbed52c2b28aab05fe5" alt="en-us_image_0000001215066868"**Properties** and set **Content** of the **Text** component to **Hello World**. Click data:image/s3,"s3://crabby-images/c955c/c955c4cc0b59e1e16c6fba55ce854109a40b2590" alt="en-us_image_0000001215386842"**Feature**, and set **FontSize** to **60px** and **TextAlign** to **center**. Then, select the **Text** component on the canvas and drag its corners to fully display the text. Below is an illustration of the operations.
data:image/s3,"s3://crabby-images/041ac/041acd0f0fa49a1ed01a3e448c0d15015297101b" alt="en-us_image_0000001216446670"
4. Add a **Button** component.
Drag the **Button** component from the **UI Control** area to a position under the **Text** component on the canvas. In the **Attributes & Styles** area on the right, click data:image/s3,"s3://crabby-images/62fc6/62fc69a003ae96a880c761521ebf3cc6590c6eef" alt="en-us_image_0000001260106745"**Properties** and set **Value** of the **Button** component to **Next**. Click data:image/s3,"s3://crabby-images/213b3/213b3bec45e460351d7474df4e4cb4000852fa2d" alt="en-us_image_0000001259866741"**Feature** and set **FontSize** to **40px**. Then, select the **Button** component on the canvas and drag its corners to fully display the text. Below is an illustration of the operations.
data:image/s3,"s3://crabby-images/05cf0/05cf012e6592426b01d020ea3fc5a587672f77f1" alt="en-us_image_0000001260928361"
5. On the toolbar in the upper right corner of the editing window, click **Previewer** to open the Previewer.
Below is how the first page looks on the Previewer.
data:image/s3,"s3://crabby-images/5f776/5f776df6b90b184f44f059765ad4d5de8feb9703" alt="en-us_image_0000001216288558"
## Building the Second Page
1. Create the second page.
In the **Project** window, choose **entry** > **src** > **main** > **js** > **MainAbility**, right-click the **pages** folder, choose **New** > **Visual**, name the page **second**, and click **Finish**. Below, you can see the structure of the **pages** folder.
data:image/s3,"s3://crabby-images/12270/12270dcf9a3e2196cb16a165545e5abbcdf0ed1b" alt="en-us_image_0000001223882030"
2. [Delete the existing template components from the canvas.](#delete_origin_content)
3. [Add a Div component and set its styles and attributes.](#add_container)
4. Add a **Text** component.
Drag the **Text** component from the **UI Control** area to the center area of the **Div** component. In the **Attributes & Styles** area, click data:image/s3,"s3://crabby-images/5f42c/5f42c81a0338a0b12bc5bff8c871a5094a5b4d40" alt="en-us_image_0000001260227453"**Properties** and set **Content** of the **Text** component to **Hi there**. Click data:image/s3,"s3://crabby-images/22fce/22fce431b152c391ae135e460c285171a1d6a998" alt="en-us_image_0000001260107497"**Feature**, and set **FontSize** to **60px** and **TextAlign** to **center**. Then, select the **Text** component on the canvas and drag its corners to fully display the text. Below is an illustration of the operations.
data:image/s3,"s3://crabby-images/1e240/1e240c3a98b7ee7cfc181618b6d17ee7d25580fb" alt="en-us_image_0000001216614132"
5. Add a **Button** component.
Drag the **Button** component from the **UI Control** area to a position under the **Text** component on the canvas. In the **Attributes & Styles** area on the right, click data:image/s3,"s3://crabby-images/ee5cb/ee5cbdbc2af68e147eba9d7e0674f8ebeef69952" alt="en-us_image_0000001215227618"**Properties** and set **Value** of the **Button** component to **Back**. Click data:image/s3,"s3://crabby-images/a2b02/a2b02e3932590b09a75d6b8c35e17d32bc9e727c" alt="en-us_image_0000001259987441"**Feature** and set **FontSize** to **40px**. Then, select the **Button** component on the canvas and drag its corners to fully display the text. Below is an illustration of the operations.
data:image/s3,"s3://crabby-images/ab65b/ab65bf533c1e5649ac23a5fbcbe2c4ed975711c9" alt="en-us_image_0000001261017331"
## Implementing Page Redirection
You can implement page redirection through the [page router](../ui/ui-js-building-ui-routes.md), which finds the target page based on the page URI. Import the **router** module and then perform the steps below:
1. Implement redirection from the first page to the second page.
In the files of the first page, bind the **onclick** method to the button so that clicking the button redirects the user to the second page. This operation needs to be completed in both .js and .visual files.
- In the **index.js** file:
```js
import router from '@ohos.router';
export default {
onclick() {
router.push({
url:'pages/second/second', // Specify the page to be redirected to.
})
}
}
```
- In the index.visual file, select the **Button** component on the canvas. In the **Attributes & Styles** area, click data:image/s3,"s3://crabby-images/4b29f/4b29fe07f8e800d5f3fdf8b2af5498e5969220b8" alt="en-us_image_0000001215388136"**Events** and set **Click** to **onclick**.
data:image/s3,"s3://crabby-images/5799f/5799f06f50e528e15346101c77c0540456685e4e" alt="en-us_image_0000001223722586"
2. Implement redirection from the second page to the first page.
In the files of the second page, bind the **back** method to the **Back** button so that clicking the button redirects the user back to the first page.
This operation needs to be completed in both .js and .visual files.
- In the **second.js** file:
```js
import router from '@ohos.router';
export default {
back() {
router.back()
}
}
```
- In the **second.visual** file, select the **Button** component on the canvas. In the **Attributes & Styles** area, click data:image/s3,"s3://crabby-images/0bd42/0bd427cd7a7493276907034ebad8785082876a43" alt="en-us_image_0000001215388262"**Events** and set **Click** to **back**.
data:image/s3,"s3://crabby-images/68505/685052b700707d4966bacd4fe267e105097d685d" alt="en-us_image_0000001268082945"
3. Open the **index.visual** or **index.js** file and click data:image/s3,"s3://crabby-images/5d837/5d8377716d81e17a28fbf0fd2ac6dbd63f289e96" alt="en-us_image_0000001261979271" in the Previewer to refresh the file. The figure below shows the effect.
data:image/s3,"s3://crabby-images/fd514/fd5141311a0eb7fed7f0a7a81d6d67f9589e4945" alt="en-us_image_0000001261142799"
## Running the Application on a Real Device
1. Connect the development board running the OpenHarmony standard system to the computer.
2. Choose **File** > **Project Structure** > **Project** > **Signing Configs**, select **Automatically generate signing**, wait until the automatic signing is complete, and click **OK**, as shown below.
data:image/s3,"s3://crabby-images/7e351/7e3513ef0ca5e784a449ff7f4a7c91623181b022" alt="en-us_image_0000001268283201"
3. On the toolbar in the upper right corner of the editing window, click data:image/s3,"s3://crabby-images/1b7bb/1b7bb73bb2757a6c735fa2e83b0b76243c5717a4" alt="en-us_image_0000001262207811". The display effect is shown in the figure below.
data:image/s3,"s3://crabby-images/6df9a/6df9ae546acd3b8909b7b465674cfb7466e8f0d4" alt="en-us_image_0000001262127855"
Congratulations! You have finished developing your OpenHarmony app in JavaScript in the low-code approach. To learn more about OpenHarmony, see [OpenHarmony Overview](../application-dev-guide.md)