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

mysql网站数据库自学网页设计需要学习什么

mysql网站数据库,自学网页设计需要学习什么,涿鹿县建设局网站,php网站开发目录1. 环境搭建 插件安装:Redux Toolkit和react-redux npm i reduxjs/toolkit react-redux2、 store目录结构设计 集中状态管理的部分会单独创建一个store目录(在src下)应用通常会有很多个子模块,所以还会有个modules目录&#x…

1. 环境搭建

插件安装:Redux Toolkit和react-redux

npm i @reduxjs/toolkit react-redux

2、

store目录结构设计

  1. 集中状态管理的部分会单独创建一个store目录(在src下)
  2. 应用通常会有很多个子模块,所以还会有个modules目录,在内部编写业务分类的子store
  3. store中的入口文件index.js的作用是组合modules中的所有子模块,并导出store
    store目录结构

3、使用React Toolkit创建counterStore

创建各模块的store
counterStore.js

import { createSlice } from "@reduxjs/toolkit";// 创建store
const counterStore = createSlice({name: 'counter',// 初始化stateinitialState: {count: 0},// 修改状态的方法 reducers: {inscrement(state) {state.count++;},decrement(state) {state.count--;}}
})// 结构出actionCreater函数
const {inscrement, decrement} = counterStore.actions
// 获取reducer
const reducer = counterStore.reducer// 以按需导出的方式导出actionCreater
export {inscrement, decrement}
// 以默认导出的方式导出reducer
export default reducer

在index,js中组合store

import { configureStore } from "@reduxjs/toolkit";
// 导入子模块reducer
import counterReducer from './modules/counterStore'const store = configureStore({reducer: {counter: counterReducer}
})export default store

4、为React注入store

React-redux负责把Redux和redux连接起来,内置Provider组件通过store参数把创建好的store实例注入到应用中。

import React from 'react';
import ReactDOM from 'react-dom/client';
import './index.css';
import App from './App';
import reportWebVitals from './reportWebVitals';
import store from './store';
import { Provider } from 'react-redux';const root = ReactDOM.createRoot(document.getElementById('root'));
root.render(<React.StrictMode><Provider store={store}><App /></Provider></React.StrictMode>
);reportWebVitals();

5、在React组件中使用store中的数据

使用useSelector钩子函数,把store中的数据映射到组件中


import React from 'react';
import './App.css';import { useSelector } from 'react-redux';function App() {// 这里state.counter和store中的reducer.counter是对应的const {count} = useSelector(state => state.counter);return (<React.Fragment><div>{count}</div></React.Fragment>);
}export default App;

6、React组件中修改store中的数据

引入useDispatch钩子函数,作用:生成提交的action对象的dispatch函数


import React from 'react';
import './App.css';import { useDispatch, useSelector } from 'react-redux';// 倒入actionCreater
import {inscrement, decrement} from './store/modules/counterStore'function App() {// 这里state.counter和store中的reducer.counter是对应的const {count} = useSelector(state => state.counter);const dispatch = useDispatch()return (<React.Fragment><div>{/* 调用dispatch提交action对象 */}<button onClick={()=> dispatch(decrement())}> - </button><span>{count}</span><button onClick={() => dispatch(inscrement())}> + </button></div></React.Fragment>);
}export default App;

7、在action中传参

在reducers的同步修改方法中添加action对象参数,在调用actionCreator时传递参数,参数会被传递到action对象的payload属性上
定义方法:通过payload获取传入的参数

import { createSlice } from "@reduxjs/toolkit";// 创建store
const counterStore = createSlice({name: 'counter',// 初始化stateinitialState: {count: 0},// 修改状态的方法 reducers: {inscrement(state) {state.count++;},decrement(state) {state.count--;},addToNum (state, action) {// payload是固定属性state.count = action.payload}}
})// 解构出actionCreater函数
const {inscrement, decrement, addToNum} = counterStore.actions
// 获取reducer
const reducer = counterStore.reducer// 以按需导出的方式导出actionCreater
export {inscrement, decrement, addToNum}
// 以默认导出的方式导出reducer
export default reducer

使用

        <button onClick={() => dispatch(addToNum(10))}> add To 10</button><button onClick={() => dispatch(addToNum(20))}> add To 20</button>

8、异步代码

  1. store写法不变
  2. 单独封装一个函数,返回一个新函数,在新函数中:封装异步请求获取数据,并调用同步actionCreater传入异步数据生成一个action对象,并使用dispatch提交
    channelStore.js
import { createSlice } from "@reduxjs/toolkit";
import axios from "axios";const channelStore = createSlice({name: 'channel',initialState: {channelList: []},reducers: {setChannels(state, action) {state.channelList = action.payload}}
})// 异步请求部分
const {setChannels} = channelStore.actionsconst fetchChannelList = () =>{return async (dispatch) => {const res = await axios.get('http://geek.itheima.net/v1_0/channels')dispatch(setChannels(res.data.data.channels))}
}const reducer = channelStore.reducer
export {fetchChannelList}
export default reducer
  1. 组件中dispatch的写法保持不变
    store/index.js不变
import { configureStore } from "@reduxjs/toolkit";
// 导入子模块reducer
import counterReducer from './modules/counterStore'
import channelReducer from './modules/channelStore'const store = configureStore({reducer: {counter: counterReducer,channel: channelReducer}
})  export default store

在组件中使用

import React, { useEffect } from 'react';
import { useDispatch, useSelector } from 'react-redux';// 倒入actionCreater
import { fetchChannelList } from './store/modules/channelStore';function App() {const {channelList} = useSelector(state => state.channel)const dispatch = useDispatch()useEffect(() => {dispatch(fetchChannelList())}, [])return (<React.Fragment><div>{/* 调用dispatch提交action对象 */}<ul>{channelList.map(item => <li key={item.id}>{item.name}</li>)}</ul></div></React.Fragment>);
}export default App;
http://www.yayakq.cn/news/886001/

相关文章:

  • 在中国建设银行的网站上可以转账吗学做衣服上什么网站
  • h5技术建设网站wordpress只显示文字
  • 网站开发二线城市汕头教育的网站建设
  • 哪些网站可以做平面设计网站建设后期维护小魔仙
  • 360推广联盟网站自动优化
  • 高端女装品牌前十名上海建站seo
  • 太平洋网站开发沈阳模板建站软件
  • 晋城推广型网站开发如何让域名指向网站
  • 沭阳做网站好的frame wordpress
  • 网站关键词在哪北京网站制作定制
  • 如何做衣服销售网站外贸网站建设网站优化
  • 电子商务 网站开发二维码生成短链接
  • 有口碑的镇江网站优化足球比赛直播在哪看
  • 襄阳网站建设首选公司哪家好wordpress查看ftp服务器
  • 网站建设连接全球招商网加盟网
  • 东莞网站建设营销服务平台网站编程多少钱
  • 一个网站如何优化在线网页代理服务器
  • 建网站自己与租云服务器哪个好网站制作公司兴田德润怎么联系
  • 中国网站开发公司排名软件外包产生的背景和原因
  • 招聘网站开发价格wordpress底板版权
  • 河南定制网站建设报价网页qq网址
  • 微信制作网站平台网站建设有哪些
  • 家庭服务网站的营销策略网站开发电商项目的成本管理怎么写
  • 专业做中文网站网站建设合同 免责声明
  • wordpress迁移网站做网站公司有哪些
  • 淘宝电商网站怎么做怎样创建app
  • 企业建立网站的目的网页版微信读书
  • 濮阳网站建设熊掌网络高端网站建设公司哪家服务好
  • 搜索网站logo怎么做门户网站建设情况说明
  • 住房和城乡建设部建设司网站首页做网站学不需要做后台管理系统