# Getting Started with eTS in the Low-Code Approach
> data:image/s3,"s3://crabby-images/bc3db/bc3db55ffc4b16492cc139e361e34f26532d4b26" alt="icon-note.gif" **Noteļ¼**
> This feature is supported in DevEco Studio V3.0 Beta3 and later versions.
>
> The component lineup that supports low-code development in eTS is now at its preliminary stage and will be expanding in coming 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 application 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
1. Open DevEco Studio, choose **File** > **New** > **Create Project**, select **Empty Ability**, and click **Next**.
data:image/s3,"s3://crabby-images/bb68e/bb68e69cfbc9da23d666ee7f0e35651ed27179b6" alt="en-us_image_0000001233528152"
2. Go to the project configuration page, select **Enable Super Visual**, set **UI Syntax** to **eTS**, and retain the default values for other parameters.
data:image/s3,"s3://crabby-images/39d8e/39d8ec7d8ba4c748f2369bcdb99d1af192ef8957" alt="en-us_image_0000001277728569"
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/5fd1f/5fd1f04f24b1149be136aadcffd8c53b4a7b2c15" alt="en-us_image_0000001277809333"
- **entry > src > main > ets > MainAbility > pages > index.ets**: defines logical relationships, such as data and events, used on low-code pages. For details, see [About Syntactic Sugar](../ui/ts-syntactic-sugar.md). If multiple low-code development pages are created, a page folder and the corresponding **.ets** file will be created for each of these pages.
- **entry > src > main > supervisual > MainAbility > pages > 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 **Column** 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 **Column**, **Text**, and **Button** components to the first page. A column is a container component whose child components are vertically arranged. For details, see [Column](../reference/arkui-ts/ts-container-column.md).
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/42c44/42c44a6fe6fce35cd5c9fea66ff7710ca073b875" alt="en-us_image_0000001233208980"
2. Add a **Column** component and set its styles and attributes.
Drag the **Column** component from the **UI Control** area to the canvas. In the **Attributes & Styles** area on the right, click data:image/s3,"s3://crabby-images/df2dc/df2dc5e9d887f2a130fcc57707a9ef2da8bcb074" alt="en-us_image_0000001233048996"**General** and set **Height** to **100%** so that the component fills the entire screen. Click data:image/s3,"s3://crabby-images/0d0cc/0d0ccf534a1e2897ece6cd44f848afd2fd8d9c4d" alt="en-us_image_0000001233368860"**Feature** and set **AlignItems** to **center** so that the child components of the **Column** component are centered along the horizontal axis. Below is an illustration of the operations.
data:image/s3,"s3://crabby-images/4b77a/4b77a40fda2d41634ac2c1fa3c95fa6ea9c41eb7" alt="en-us_image_0000001277488977"
3. Add a **Text** component.
Drag the **Text** component from the **UI Control** area to the canvas and then to the center area of the **Column** component. In the **Attributes & Styles** area, click data:image/s3,"s3://crabby-images/2e203/2e203b218d3e3bd5dea2459b08b56ff88530d85b" alt="en-us_image_0000001277608813"**Feature**, set **Content** of the **Text** component to **this.message** (that is, **Hello World**), set **FontSize** to **30fp**, and set **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/9f8e9/9f8e9e95a5e1f3534d4dc7206a3e86e3a68bfd8a" alt="en-us_image_0000001235731706"
4. Add a **Button** component.
Drag the **Button** component from the **UI Control** area to the canvas and then to a position under the **Text** component. In the **Attributes & Styles** area on the right, click data:image/s3,"s3://crabby-images/89f77/89f77823c2baae4a8c31f498e229fb66e1b5177b" alt="en-us_image_0000001277728577"**General** and set **Height** of the **Button** component to **40vp**. Click data:image/s3,"s3://crabby-images/60b6e/60b6e908a3853fbea319ef87c2c1da819e1332d3" alt="en-us_image_0000001277809337"**Feature** and set **Label** to **Next** and **FontSize** to **25fp**. Below is an illustration of the operations.
data:image/s3,"s3://crabby-images/d0032/d0032e47bfdcabccd18bc92166a158349302a89c" alt="en-us_image_0000001235732402"
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 in the Previewer.
data:image/s3,"s3://crabby-images/5b87f/5b87fa43d6fab2ec646a5ef3a4bbf35be3fdda5f" alt="en-us_image_0000001235892798"
## Building the Second Page
1. Create the second page.
In the **Project** window, choose **entry** > **src** > **main** > **ets** > **MainAbility**, right-click the **pages** folder, choose **New** > **Visual**, name the page **second**, and click **Finish**. Below is the structure of the **pages** folder.
data:image/s3,"s3://crabby-images/4ee71/4ee7128212a62863e3d4b8df9ac61ae3b6ad53e4" alt="en-us_image_0000001233368868"
2. [Delete the existing template components from the canvas.](#delete_origin_content)
3. [Add a **Column** component and set its styles and attributes.](#add_container)
4. Add a **Text** component.
- In the **second.ets** file, set the message text content to **Hi there**. The sample code is as follows:
```
@Entry
@Component
struct Second {
@State message: string = 'Hi there'
/**
* In low-code mode, do not add anything to the build function, as it will be
* overwritten by the content generated by the .visual file in the build phase.
*/
build() {
}
}
```
- Drag the **Text** component to the canvas and then to the center area of the **Column** component. In the **Attributes & Styles** area, click data:image/s3,"s3://crabby-images/6307c/6307c4b1469855cf0d26ba78dfd98c555df05ef9" alt="en-us_image_0000001277488985"**Feature**, set **Content** of the **Text** component to **this.message** (that is, **Hi there**), set **FontSize** to **30fp**, and set **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/40ba5/40ba5beb3d49ba675873e2cc6a154c226e6ca5f5" alt="en-us_image_0000001280255513"
5. Add a **Button** component.
Drag the **Button** component from the **UI Control** area to the canvas and then to a position under the **Text** component. In the **Attributes & Styles** area on the right, click data:image/s3,"s3://crabby-images/cc42d/cc42d2395bbf9ac348a813995317b3c44c225c41" alt="en-us_image_0000001233528160"**General** and set **Height** of the **Button** component to **40vp**. Click data:image/s3,"s3://crabby-images/6a908/6a9085c149dd851d119cd8cc4ceb485a6c338fce" alt="en-us_image_0000001277728597"**Feature** and set **Value** to **Back** and **FontSize** to **25fp**. Below is an illustration of the operations.
data:image/s3,"s3://crabby-images/a0fa5/a0fa5dba9ac4ba1822711e024d90d5ac4fb1f961" alt="en-us_image_0000001280383937"
## Implementing Page Redirection
You can implement page redirection through the page router, 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 .ets and .visual files.
- In the **index.ets** file:
```
import router from '@ohos.router';
@Entry
@Component
struct Index {
@State message: string = 'Hello World'
/**
* In low-code mode, do not add anything to the build function, as it will be
* overwritten by the content generated by the .visual file in the build phase.
*/
onclick() {
router.push({
url: 'pages/second', // Specify the page to be redirected to.
})
}
build() {
}
}
```
- In the index.visual file, select the **Button** component on the canvas. In the **Attributes & Styles** area, click data:image/s3,"s3://crabby-images/b9456/b94562bfe209db157fca1e7ef97de4826ec36baf" alt="en-us_image_0000001233209020"**Events** and set **OnClick** to **this.onclick**.
data:image/s3,"s3://crabby-images/9a805/9a805cba4edc81dd5538b9dfec2bb3888cd87b2b" alt="en-us_image_0000001235745716"
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 .ets and .visual files.
- In the **second.ets** file:
```
import router from '@ohos.router';
@Entry
@Component
struct Second {
@State message: string = 'Hi there'
/**
* In low-code mode, do not add anything to the build function, as it will be
* overwritten by the content generated by the .visual file in the build phase.
*/
back() {
router.back()
}
build() {
}
}
```
- In the second.visual file, select the **Button** component on the canvas. In the **Attributes & Styles** area, click data:image/s3,"s3://crabby-images/22938/22938ac3d64da6390646de7f59f68b8d345212c5" alt="en-us_image_0000001233368900"**Events** and set **OnClick** to **this.back**.
data:image/s3,"s3://crabby-images/bde80/bde8042bc2d58128e6217cde84acd75fa5aa251d" alt="en-us_image_0000001280385809"
3. Open the **index.visual** or **index.ets** file and click data:image/s3,"s3://crabby-images/de9cd/de9cd48ce319c9297c7999ab1e03f220f4c040d0" alt="en-us_image_0000001277608849" in the Previewer to refresh the file. The figure below shows the effect.
data:image/s3,"s3://crabby-images/e2256/e2256cd6838be6fc9964f2548a5711da902a55fe" alt="en-us_image_0000001233528192"
## 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/b6d9f/b6d9fd2ab7927ead5ad7b5b82422594bf952c256" alt="en-us_image_0000001277728613"
3. On the toolbar in the upper right corner of the editing window, click data:image/s3,"s3://crabby-images/bc350/bc350f6bbdfba4340cc9e30c58c3efc517f3bd9e" alt="en-us_image_0000001277809373". The display effect is shown in the figure below.
data:image/s3,"s3://crabby-images/23b03/23b03c3ba8e6f37ae4014864459b73f8dc7b451f" alt="en-us_image_0000001233209024"
Congratulations! You have finished developing your OpenHarmony application in eTS in the low-code approach. To learn more about OpenHarmony, see [OpenHarmony Overview](../application-dev-guide.md).