当前位置: 首页 > news >正文

新郑做网站公司网页设计公司名称

新郑做网站公司,网页设计公司名称,如何建设专业化的网站,小型企业网站开发公司方式一:使用create-react-app命令创建项目 1、使用以下命令初始化一个空的npm 项目 npm init -y 2、输入以下命令安装React npm i create-react-app ps:如果失败的话尝试(1:使用管理员身份执行命令(2:切换镜像重…

方式一:使用create-react-app命令创建项目

1、使用以下命令初始化一个空的npm 项目

npm init -y 

2、输入以下命令安装React

npm i create-react-app

ps:如果失败的话尝试(1:使用管理员身份执行命令(2:切换镜像重试

3、输入以下命令创建项目

create-react-app 项目文件夹名称 --template typescript//如果不想用ts  --template typescript 可以不加

4、然后根据终端界面上的提示命令就可以打开项目了

接下来就是一些配置、路由、网络封装什么的。

方法二:使用vite创建项目(简单快捷)

1、执行以下命令

npm create vite 项目文件夹名称

选择自己想要的一些框架和配置

2、根据提示执行对应命令就可以打开项目了

接下来就是一些配置、路由、网络封装什么的。

关于配置

1、打开vite官网进行vite的相关一些配置 配置 Vite | Vite 官方中文文档
(1 配置路径别名 需要安装path
npm i @types/node --save-dev

 在vite.config.ts 引入path加上下面的代码片段

import { defineConfig } from 'vite';
import react from '@vitejs/plugin-react';
import {resolve} from "path";
export default defineConfig({plugins: [react()],resolve:{alias:{"@":resolve(__dirname,'src')}}
})

同时在tsconfig.json 让IDE能识别这个别名

  "compilerOptions": {"paths": {"@/*":["./src/*"]}},
2、执行下列命令安装less 
npm install less

然后在vite.config.ts中进行相关配置


export default defineConfig({plugins: [react()],resolve: {alias: {'@': resolve(__dirname,'src')}},css: {preprocessorOptions: {less: {javascriptEnabled: true,}}}
3、不同环境打包后端接口地址不同相关配置
(1 在你的项目根目录中创建 .env.development 和 .env.production 文件,分别用于开发环境和生产环境的配置。
// .env.developmentVITE_API_URL=http://localhost:3000/api

 

// .env.productionVITE_API_URL=https://example.com/api
(2 修改网络封装请求中的baseUrl改成
const apiUrl = import.meta.env.VITE_API_URL as string;
 (3 在 package.json 的 scripts 中添加如下命令
{"scripts": {"dev": "vite --mode development","build": "vite --mode production"}
}

关于路由

1、执行下列命令安装router
npm i react-router-dom@6
(1 在src文件目录下创建router文件夹 

然后在router文件夹下创建index.tsx文件

/src/router/index.tsx

import type { RouteObject,} from 'react-router-dom';
import { Navigate } from "react-router-dom";
import { lazy } from 'react';const Home = lazy(() => import('@/pages/Home'));
const NotFound = lazy(() => import('@/pages/NotFound'));//使用路由懒加载优化提升const routes: RouteObject[] = [{path: "/",element: <Navigate to="/home" />,},{path: '/404',element: <NotFound />,},{path: '/home',element: <Home />,// children: [//     {//         index : true,//         element: <Home />//     },//     {//         path: "/about",//         element: <About />,//         children: [//             { index : true, element: <AboutIndex />},//             { path : "/about/:id", element :<AboutList />}//         ]//     },//     {//         path: "/bussiness",//         element: <Bussiness />,//     }// ]},
];export default routes;
(2 在scr/App.tsx文件中加入

import React from 'react';
import './App.css';
import { useRoutes } from 'react-router';
import routes from './route';function App() {return (<div className="App">{useRoutes(routes)}</div>);
}export default App;
(3 在scr/main.tsx文件中配置路由模式
import React from 'react';
import ReactDOM from 'react-dom/client';
import App from './App';
import './index.css';
import { BrowserRouter } from 'react-router-dom';
ReactDOM.createRoot(document.getElementById('root') as HTMLElement).render(<React.StrictMode><BrowserRouter><App /></BrowserRouter></React.StrictMode>
);

关于网络请求封装

1、先安装Axios库

npm install axios @types/axios
(1 在src目录下创建apis文件夹接着创建api.tsx文件夹 用于封装网络请求逻辑
import axios from 'axios';
import {baseInfo} from "../common/config";
import {getToken,removeToken,} from "../common/storage";
export function requestAdmin(config){let Token = getToken();if(Token){config.headers={...config.headers,'Token' : `${Token}`,'Authorization' : `token`,}}const instance = axios.create({baseURL:"",headers:{...config.headers},timeout:100000});// axios请求拦截器 请求instance.interceptors.request.use(config=>{return config;},err=>{console.log(err);})// axios响应拦截器 数据返回instance.interceptors.response.use(res=>{let {code,message} = res.data;//判断用户登录的token是否过期做某些操作if(code === ...){}return res;},err=>{console.log(err);})return instance(config);
}
(2 接口统一封装
//引用axios封装函数
import {requestAdmin} from "@/network/request";/*** 登录* @param data*/
export function doLogin(data:any){return requestAdmin({url:"",data,method:"post"})
}

 (3 使用

//引入network的网络请求接口
import { requestLogin } from "@/network/v1/login/index"
interface InitProps{}
const Login:FC<InitProps> = (props:InitProps)=>{
const onLogin = (values: any) => {let data = {};requestLogin(data).then((res: resInterface) => {let { code, data,message } = res.data;if (code === 200) {showSuccess('登录成功');setToken(data.token);setTimeout(_ =>{setLoading(false)},1000)} else {showError(`${message}`);setLoading(false)}}).catch((err:any) => {console.log(err);})};return (<React.Fragment><Button onClick={onLogin}>去登录</Button></React.Fragment>)
}export default Login;

关于UI框架配置

这里可以自行选择适合自己的框架类似于antd、Material UI...等

这里我选的是移动端Material UI 官方文档 Installation - Material UI

(1 先安装框架

npm install @mui/material @emotion/react @emotion/styled

(2 引入框架与使用(按需引入)

import { useState } from 'react';
import { Button } from '@mui/material';import Container from '@mui/material/Container';
import { styled } from '@mui/material/styles';
import Box from '@mui/material/Box';
import Paper from '@mui/material/Paper';
import Grid from '@mui/material/Grid';function Home() {const [count, setCount] = useState(0);const Item = styled(Paper)(({ theme }) => ({backgroundColor: theme.palette.mode === 'dark' ? '#1A2027' : '#fff',...theme.typography.body2,padding: theme.spacing(1),textAlign: 'center',color: theme.palette.text.secondary,}));return (<Container fixed><Box sx={{ flexGrow: 1 }}><Grid container spacing={2}><Grid item xs={12}><Item>banner区域</Item></Grid><Grid item xs={12}><Item>广告区域</Item></Grid><Grid item xs={4}><Item>xs=4</Item></Grid><Grid item xs={8}><Item>xs=8</Item></Grid></Grid></Box></Container>);
}export default Home;

以上就是所有内容,感谢阅读。

http://www.yayakq.cn/news/122420/

相关文章:

  • 网站建设优化及推广网站页面框架设计影响用户
  • 建设网站招聘做盗版小说网站违法吗
  • 网站的建设公司简介wordpress添加一级菜单
  • 网站策划案例wordpress建响应网址
  • 网站中文域名到期有关网站空间正确的说法是
  • 网络设计一个月多少钱如何优化搜索关键词
  • 上海三凯监理建设管理咨询公司网站免费制作app的软件下载
  • 网站到底是域名需要备案还是空间全网精选小程序
  • 创业开网站建设公司济南网络公司注册
  • 网站设计英语学校网站开发研究的意义和目的
  • 合肥网站开发培训学校wordpress 文章数量
  • 郑州网络营销与网站推广域名可以永久买断吗
  • 鲁山网站建设迷你世界怎么做网站期
  • wap网站建设服务前端与移动开发
  • tp5 网站开发免费订单管理app
  • 网站空间的管理站点温州本地网站
  • 做网站费用列入什么科目苏州抖音代运营公司
  • 网站文章被采集自适应网站建设软件
  • 网站定制化开发营销型网站建设需要注意什么
  • 云速建站与传统网站的区别网站文件下载系统
  • 泰安网站推广公关公司服务的特点包括
  • 商务网站规划与建设课程设计交易平台官网
  • 嘉兴网站优化联系方式建设网站要求有哪些
  • 房地产网站cms厦门网红打卡地
  • asp.net 网站图标wordpress国产微课主题
  • 网站加友情链接的好处erp办公系统软件
  • 网站建设 重庆网站静态与动态
  • 网站建设客户案例猪八戒网站开发
  • 网站建设评审表福州网站制作工具
  • 做租房网站网站栏目页描述怎么写