1# "js" Tag 2 3 4The "js" tag contains the instance name, window style, and page route information. 5 6 7| Tag | Data Type | Default Value | Mandatory | Description | 8| -------- | -------- | -------- | -------- | -------- | 9| name | string | default | Yes | Name of the JavaScript instance. | 10| pages | Array | - | Yes | Route information. For details, see ["pages"](#pages). | 11| window | Object | - | No | Window information. For details, see ["window"](#window). | 12 13 14> **NOTE** 15> 16> The "name", "window", and "pages" tags are configured in the "js" tag of the **config.json** file. 17 18 19## "pages" 20 21The "pages" defines the route information of each page. Each page consists of the page path and page name. The following is an example: 22 23```json 24{ 25 ... 26 "pages": [ 27 "pages/index/index", 28 "pages/detail/detail" 29 ] 30 ... 31} 32``` 33 34 35> **NOTE** 36> 37> - The first page in the pages list is the home page, also referred to as the entry, of the application. 38> 39> 40> - The page name should not be a component name, for example, text.hml or button.hml. 41 42## window 43 44The "window" defines window-related configurations. To solve the screen adaptation problem, you can use either of the following methods: 45 46- Specify designWidth, which is the logical screen width. All size styles, such as width and font-size, are scaled at the ratio of designWidth to the physical screen width. For example, when designWidth is 720 px and if you set width to 100 px, the actual display width is scaled to 200 physical px on the screen whose physical width is 1440 px. 47 48- Set autoDesignWidth to true, the designWidth field will be ignored, and the component and layout will be scaled automatically based on the screen density. The logical screen width is automatically calculated based on the physical screen width and screen density. The logical screen width may vary depending on the device. Use the relative layout to adapt to different devices. For example, on a device with a resolution of 466x466 and 320 DPI (a screen density of 2x, with 160 DPI as the base), 1 px is equivalent to 2 physical px. 49 50 > **NOTE** 51 > 52 > 1. The default <length> value in the current style is calculated based on the screen density. For example, if the screen density is x2 (with 160 DPI as the baseline) and the default <length> value is 1 px, the actual length rendered on the device is 2 physical px. 53 > 54 > 2. Values of autoDesignWidth and designWidth do not affect how the default <length> value is calculated and the final effect. 55 56 57| Attribute | Type | Mandatory | Default Value | Description | 58| -------- | -------- | -------- | -------- | -------- | 59| designWidth | number | No | 720 | Logical screen width, which is a reference value for page design. The actual display width is scaled at the ratio of the value to the device width. | 60| autoDesignWidth | boolean | No | false | Whether to automatically calculate the baseline width. If autoDesignWidth is set to true, designWidth is ignored. The baseline width is calculated based on the physical screen width and screen density. | 61 62The following is a sample code snippet: 63 64```json 65{ 66 ... 67 "window": { 68 "designWidth": 720, 69 "autoDesignWidth": false 70 } 71 ... 72} 73``` 74 75 76## Example 77 78 79```json 80{ 81 "app": { 82 "bundleName": "com.example.player", 83 "version": { 84 "code": 1, 85 "name": "1.0" 86 }, 87 "vendor": "example" 88 } 89 "module": { 90 ... 91 "js": [ 92 { 93 "name": "default", 94 "pages": [ 95 "pages/index/index", 96 "pages/detail/detail" 97 ], 98 "window": { 99 "designWidth": 720, 100 "autoDesignWidth": false 101 } 102 } 103 ], 104 "abilities": [ 105 { 106 ... 107 } 108 ] 109 } 110} 111``` 112