1 Star 0 Fork 0

于鑫洋/React+ts(pc)

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
该仓库未声明开源许可证文件(LICENSE),使用请关注具体项目描述及其代码上游依赖。
克隆/下载
create.js 1.89 KB
一键复制 编辑 原始数据 按行查看 历史
于鑫洋 提交于 2023-12-24 12:54 . 上传
// 命令 node create.js film
// + router/routes/film.tsx 并定义好路由
// + views/film/index.tsx 电影列表页面
const path = require('path')
const fs = require('fs')
const routerTemplate = name => {
const cmp = name.slice(0, 1).toLocaleUpperCase() + name.slice(1)
return `
import { Suspense, lazy } from 'react'
import { Outlet, type RouteObject } from 'react-router-dom'
import { Spin } from 'antd'
const ${cmp} = lazy(() => import('@/views/${name}'))
const routes: RouteObject[] = [
{
path: '${name}',
element: <Outlet />,
children: [
{
path: 'list',
element: (
<Suspense fallback={<Spin size='large' />}>
<${cmp} />
</Suspense>
)
}
]
}
]
export default routes
`
}
const viewTemplate = name => {
const cmp = name.slice(0, 1).toLocaleUpperCase() + name.slice(1)
return `
import {useState,useEffect} from 'react'
import type {FC} from 'react'
const ${cmp} = () => {
return (
<div>
<h3>${cmp}</h3>
</div>
);
}
export default ${cmp}
`
}
// 得到当前命令执行的目录路径
const cwd = process.cwd()
// 得到执行的命令参数中文件名称和目录名称
const name = process.argv[2]
// 路由根路径
const routerRoot = path.join(cwd, 'src/router/routes')
// 视图根路径
const viewRoot = path.join(cwd, 'src/views')
// 创建路由文件
const routerPath = path.join(routerRoot, `${name}.tsx`)
// 路由不存在才创建
if (!fs.existsSync(routerPath)) {
fs.writeFileSync(routerPath, routerTemplate(name))
}
// 创建视图目录
const viewPath = path.join(viewRoot, name)
// 视图目录不存在才创建
if (!fs.existsSync(viewPath)) {
fs.mkdirSync(viewPath)
// 在视图目录下创建 index.tsx 文件
const viewFilePath = path.join(viewPath, 'index.tsx')
fs.writeFileSync(viewFilePath, viewTemplate(name))
}
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
1
https://gitee.com/Y-u-xin-yang/react-ts-pc.git
git@gitee.com:Y-u-xin-yang/react-ts-pc.git
Y-u-xin-yang
react-ts-pc
React+ts(pc)
master

搜索帮助

0d507c66 1850385 C8b1a773 1850385