Skip to content

Commit

Permalink
areact getting started + theme changed
Browse files Browse the repository at this point in the history
  • Loading branch information
tobylai-toby committed Sep 22, 2024
1 parent 477c1a1 commit d853587
Show file tree
Hide file tree
Showing 11 changed files with 448 additions and 6 deletions.
219 changes: 219 additions & 0 deletions docs/areact/getting-started.mdx
Original file line number Diff line number Diff line change
@@ -0,0 +1,219 @@
---
title: 快速上手
---

import Tabs from '@theme/Tabs';
import TabItem from '@theme/TabItem';

# 快速上手
:::warning
本文默认你已经掌握 **ArenaPro(或者ArenaLess)** 插件的基本用法,如未了解,请先阅读[ArenaPro](https://www.yuque.com/box3lab/arenapro)插件文档。
:::
本篇文章将让您快速入门Areact,从项目创建、配置到开发、部署。

## 环境要求
1. VSCode(版本尽可能在1.93左右)
:::tip
如果无法使用桌面端VSCode配合AP/AL进行开发,那么可以试一试[vscode.dev](https://vscode.dev)+[ArenaLess](/docs/arenaless/)的组合
:::
2. VSCode扩展 [ArenaPro(AP)](https://www.yuque.com/box3lab/arenapro)或者[ArenaLess(AL)](/docs/arenaless/)

## 创建项目并完成JSX配置
### 1. 创建项目
在VSCode中按下<kbd>Ctrl+Shift+P</kbd>,输入命令并找到创建项目的命令,运行它。
:::note
- 在 ArenaPro 中,这个命令叫`ArenaPro: 新建Arena-Ts项目`
- 在 ArenaLess 中,这个命令叫`ArenaLess: 创建ArenaLess项目`

这两个扩展创建的项目结构几乎是相同的
:::
### 2. 修改文件名和入口点
-`client/src/clientApp.ts` 重命名为-> `client/src/clientApp.tsx`
-`dao3.config.json` 中的 `client->entry` 改为 `src/clientApp.tsx`(类似下面这样)
```js title="dao3.config.json"
{
"client": {
"base": "./client",
// 修改这里
"entry": "src/clientApp.tsx",
//...省略...
}
}
```
### 3. 修改client/tsconfig.json
需要在`compilerOptions`中加入一些`jsx/tsx+areact`相关的配置
```js title="client/tsconfig.json"
{
"compilerOptions": {
// ...省略...
// 这四行是要添加的内容
"noImplicitAny": false,
"jsx": "react",
"jsxFactory": "Areact.h",
"jsxFragmentFactory": "Areact.frag"
// ...省略...
}
}
```
:::info
请记住,如果你下次还要创建一个这样的项目的话依旧要完成以上步骤
:::
## 安装 Areact
对于ArenaPro和ArenaLess有不同的安装步骤。
<Tabs>
<TabItem value="ap" label="ArenaPro Creator" default>
```sh title="在项目根目录打开VSCode的终端,输入以下命令:"
npm install --save dao3-areact
```
</TabItem>
<TabItem value="al" label="ArenaLess">
```js title='在importMap.arenaless.jsonc的"imports"中添加:'
{
"imports":{
// 在这里加入一条导入
"dao3-areact":"npm:dao3-areact"
}
}
```
</TabItem>
</Tabs>

## 你的第一段代码
好了,所有的配置工作完工了,现在开始写你的第一段代码吧!
<details>
<summary>点击查看完整代码</summary>
```tsx title="client/src/clientApp.tsx"
import { Areact, hooks } from "dao3-areact";
import { Text } from "dao3-areact/components";
let app = new Areact();
function App() {
const [count,setCount]=hooks.useState(0);
return (<>
<Text x="0px" y="0px" height="50px" width="200px"
backgroundColor="#000000"
textColor="#ffffff"
backgroundOpacity="100%"
text={`你点我点了${count}下`}
onClick={(e)=>{setCount(count+1)}}
></Text>
</>);
}
app.mount(<App />, ui);
```
</details>

> 接下来是分解教程
### 1. 导入
```tsx
import { Areact, hooks } from "dao3-areact";
import { Text } from "dao3-areact/components";
```
- `Areact`是框架
- `hooks``react(preact)``hooks`,详见[Built-in React Hooks(React文档)](https://react.dev/reference/react/hooks)
- `Text`是一个文本组件,就类似原岛三ui中的UiText,以下是所有的组件:
- `Text` 显示文本的组件
- `Image` 显示图片的组件
- `Input` 显示输入框的组件
- `Box` 一个框架组件,没有什么特征
### 2. 创建 入口点组件
```tsx
let app = new Areact();
function App() {
// 待会添加的内容
return (<>
{/* ... 这里是待会要填充的组件 ...*/}
</>);
}
// 将入口点组件挂载到Areact上运行渲染
app.mount(<App/>,ui)
```
最基础的部分已经ok了,但是你现在运行见不到任何效果,那是因为你还没有添加其他组件。
### 3. 文本组件
接下来,我们修改`function App(){}`的内容,添加一个文本组件:
```tsx
function App() {
// 待会添加的内容
return (<>
<Text x="0px" y="0px" height="50px" width="200px"
backgroundColor="#000000"
textColor="#ffffff"
backgroundOpacity="100%"
text={`我是一个文本框`}
></Text>
</>);
}
```
<details>
<summary>讲解一下以上的各个属性(属性值大多用字符串)</summary>
:::info
1. `x`,`y`,`width`,`height`这些属性的格式是这样的:`<偏移数值>px+<百分比比例>%`,其中可以把`+`换成`-`,甚至多加几个`+和-`都是允许的。

最后会被转换为`offset``scale`值。例子`10px`,`10px+20%`,`10px+20%-20px+10%`
2. `text` 这是适用于`Text``Input`的组件的属性,代表文本内容。相当于岛三ui的`textContent`

因为react占用了`textContent`这个属性,所以我们用了`text`代替。
3. `backgroundColor`,`textColor` 前者是背景颜色,后者是文本颜色。接收css的颜色值,会自动转换为rgb的vec3。
4. `backgroundOpacity` 背景不透明度,接受百分数
:::
</details>
好,现在左上角出现了一个黑色底,白色字的文本框。
### 4. 添加事件和state
一个文本框太过单调了……如果我们想点击它改变显示的文字呢?例如点击显示的数字+1。
- 使用`hooks.useState()`来创建一个状态变量,当这个变量使用`setXXX`更新时,会重新渲染使用了该变量的组件,
这样我们在点击的时候把`count`变量+1,文本框的文本会随之变化。
- 使用`onClick`属性来注册点击事件,并且更新状态变量`count`

这是`useState`的一般用法:
```tsx
let [name,setName]=hooks.useState("tobylai");// tobylai就是你指定的默认值
// 前者是用于读取的变量,后者是更新变量时所用的函数
// 这个命名取决于你,规范的写法是[aaa,setAaa]
console.log(name); // "tobylai"
setName("Areact"); // 这里更新了状态变量
console.log(name); // "Areact"
```
让我们修改先前的代码,得到最终成品:
```tsx
import { Areact, hooks } from "dao3-areact";
import { Text } from "dao3-areact/components";
let app = new Areact();
function App() {
// 这个状态变量count初始值为0,调用setCount可以改变它
const [count,setCount]=hooks.useState(0);
return (<>
<Text x="0px" y="0px" height="50px" width="200px"
backgroundColor="#000000"
textColor="#ffffff"
backgroundOpacity="100%"
text={`你点我点了${count}下`}// 这里的文本会随count自动更新
onClick={(e)=>{setCount(count+1)}}// onClick事件,把count设置为count+1
></Text>
</>);
}
app.mount(<App />, ui);
```
现在你就得到了一个点击就能+1的文本框了,像不像个电子木鱼?

## 更远……文本框+输入框
以下代码可以实现在输入框输入文字的过程中更新文本框的内容
```tsx
import { Areact, hooks } from "dao3-areact";
import { Text,Input,Box,Image } from "dao3-areact/components";
let app = new Areact();

function App() {
const [name,setName]=hooks.useState("");
return (<>
<Text x="0px" y="0px" height="50px" width="200px" text={`你好啊!${name}`}
backgroundColor="#000000"
textColor="#ffffff"
backgroundOpacity="100%"
></Text>
<Input x="0px" y="50px" width="200px" height="50px" placeholder="请输入你的名字:"
onInput={(e)=>setName(e.target.getAttribute("text"))} // 使用onInput事件监听输入
text={name} // 绑定是双向的~
></Input>
</>);
}
app.mount(<App />, ui);
```
56 changes: 56 additions & 0 deletions docs/areact/index.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,56 @@
---
title: Areact
---

# Areact
:::warning 使用前三思
目前神岛client端编辑器的优化很烂,过大的体积会导致地图无法打开。而目前此库体积`256kb`左右,有几率导致崩溃……
- 呼叫大板砖支援
- 呼叫大板砖支援
- 呼叫大板砖支援
:::
Areact是一个基于Preact的UI框架,能够在[神奇代码岛](https://dao3.fun)上利用类似React的方式创建UI界面。

## 快速开始
:::info[快速上手]
需要新手入门教程?请点击[这里](./getting-started)
:::


## 速览(简单示例)
![1726978076891](index/1726978076891.png)
```tsx title="clientApp.tsx"
import { Areact, hooks } from "dao3-areact";
import { Text } from "dao3-areact/components";
let app = new Areact();
// 这是UI的根组件
function App() {
const [count,setCount]=hooks.useState(0);
return (<>
{/* 文字组件,点击+1 */}
<Text x="0px" y="0px" height="50px" width="200px"
backgroundColor="#000000"
textColor="#ffffff"
backgroundOpacity="100%"
text={`你点我点了${count}下`}
onClick={(e)=>{setCount(count+1)}}
></Text>
</>);
}
// 挂载根组件 开始渲染
app.mount(<App />, ui);
```

## 优势
-[ArenaPro](https://www.yuque.com/box3lab/arenapro)或者[ArenaLess](/docs/arenaless/)结合使用,TypeScript助力开发
- React 的写法,有React的优点,例如状态更新等
- 支持`React``Hooks`,例如`useState``useEffect`
- 事件写法更为清晰,可以在节点上`onClick`,`onInput`
- 组件化的编程方式,十分简单地创建起属于你的组件库,避免了复制粘贴。
- 近似于`html`的风格,有特色的组件参数绑定

## 缺点
- 性能开销略高
- 可能会出现bug
- 打包体积较大,输出`256kb`左右,可能会导致地图崩溃
- 有一些神岛自带的组件无法使用,原因是搬砖没有写JavaScriptAPI,只做了编辑器……
Binary file added docs/areact/index/1726978076891.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
4 changes: 4 additions & 0 deletions docs/dao3-aui/getting-started.mdx
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,10 @@ sidebar_position: 2
import Tabs from '@theme/Tabs';
import TabItem from '@theme/TabItem';

:::danger 迁移!
dao3-aui不再维护,请迁移到Areact
:::

# 快速上手
:::warning
本文默认你已经掌握 **ArenaPro(或者ArenaLess)** 插件的基本用法,如未了解,请先阅读[ArenaPro](https://www.yuque.com/box3lab/arenapro)插件文档。
Expand Down
7 changes: 6 additions & 1 deletion docs/dao3-aui/index.md
Original file line number Diff line number Diff line change
@@ -1,6 +1,11 @@
---
title: Dao3-AUI (React on 神岛)
title: ⚠迁移 Dao3-AUI
---

:::danger 迁移!
dao3-aui不再维护,请迁移到Areact
:::

# Dao3-AUI
Dao3-AUI是**开源**的,如果你有需求或者bug汇报,请到[本项目repo](https://github.com/Box3TRC/dao3-aui)开issue。
## 什么是Dao3-AUI ⚛️+📦
Expand Down
35 changes: 35 additions & 0 deletions docusaurus.config.js
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,7 @@
// See: https://docusaurus.io/docs/api/docusaurus-config

import { themes as prismThemes } from 'prism-react-renderer';
import tabBlocks from "docusaurus-remark-plugin-tab-blocks";

/** @type {import('@docusaurus/types').Config} */
const config = {
Expand Down Expand Up @@ -40,13 +41,15 @@ const config = {
/** @type {import('@docusaurus/preset-classic').Options} */
({
docs: {
remarkPlugins: [[tabBlocks,{}]],
sidebarPath: './sidebars.js',
// Please change this to your repo.
// Remove this to remove the "edit this page" links.
editUrl:
'https://github.com/Box3TRC/documentation/blob/main',
},
blog: {
remarkPlugins: [tabBlocks],
showReadingTime: true,
// Please change this to your repo.
// Remove this to remove the "edit this page" links.
Expand Down Expand Up @@ -141,6 +144,38 @@ const config = {
explicitSearchResultPath: true,
}),
],
],plugins:[
// [
// 'vercel-analytics',
// {
// debug: true,
// mode: 'auto',
// },
// ],
// [
// 'docusaurus-plugin-typedoc',
// {
// id: 'typedoc-areact',
// entryPoints: ['dts/areact/index.d.ts'],
// skipErrorChecking: true,
// name: "模块: areact",
// out: "/docs/areact/api/index",
// sidebar: {
// "autoConfiguration": false,
// "pretty": false
// }
// },
// ],
// [
// 'docusaurus-plugin-typedoc',
// {
// id: 'typedoc-areact-components',
// entryPoints: ['dts/areact/components.d.ts'],
// skipErrorChecking: true,
// name: "模块: areact/components",
// out: "/docs/areact/api/components"
// },
// ],
]
};

Expand Down
Loading

0 comments on commit d853587

Please sign in to comment.