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

微企点建站平台介绍wordpress基本函数

微企点建站平台介绍,wordpress基本函数,wordpress如何上传图片,wordpress 替代前言: redux是一种状态管理工具,可以存储和操作一些全局或者很多组件需要使用的公共数据。 平心而论,redux的使用对于新上手来说不太友好,多个依赖包的,多种api的结合使用,相对来说比做同样一件事的vuex用起来比较麻烦.不过,熟能生巧,用多了也就习惯了,下面是个人的一个demo,…前言: redux是一种状态管理工具,可以存储和操作一些全局或者很多组件需要使用的公共数据。 平心而论,redux的使用对于新上手来说不太友好,多个依赖包的,多种api的结合使用,相对来说比做同样一件事的vuex用起来比较麻烦.不过,熟能生巧,用多了也就习惯了,下面是个人的一个demo,是自己根据尚硅谷张天禹react教程学习的,然后写的demo. 这个demo是一个实用版本的demo,而不是深入研究redux本身的各种api操作 思路和准备: 需要的依赖包: redux : 状态管理的核心插件(不仅仅是在react中能用,也可以在vue中用,但很显然,vue不需要 !--) react-redux : 专门让redux和react之间对接的一个插件,让redux写起来没有那么的麻烦,(相对没有) redux-devtools-extension : 调试工具,类似于vue-devtools,方便调试和查看,(当然了,本人是console.log党,用得少,配置上就行了) redux-thunk: 可以让redux的值进行异步的修改,比较重要,能节省不少东西 思路: 首先,先要创建一个store,store是每个组件访问的核心,就像淘宝网站一样. 然后每个网站里面都有自己的商店,不同的商店对应不同的商品和购买方式,所以你就需要针对具体的数据类型,配置具体操作他的方法. 然后每个组件就像消费者一样,可以直接访问淘宝网站和站内所有的店铺,并且可以选取你希望他方式购买他,并且你的消费对其他客户也会造成影响,比如这件商品只剩一件了,你买了,其他用户就没货了,这也就是全局数据状态共享的意义. ok了.学会了这些,那就直接展示代码了,感觉条例还是比较清晰的. 文件结构 |-- src(业务文件夹)        ---------------互联网世界 |--pages(普通组件文件夹)    --------------电商领域      |--index.jsx(demo父组件)    --------------消费者集合 |--demo1.jsx(子组件1)   --------------消费者1 |--demo2.jsx(子组件2)   --------------消费者2 |--redux(redux文件夹) |--actions(修改demo1数据状态的操作函数集合)  ------------消费者购物方式集合 |--demo1Actions.js(demo1数据操作方法)     -------------京东支付,选择加急,使用京豆 |--demo2Actions.js(demo2数据操作方法)     -------------微信支付,不着急,坐等快递 |--reducers(全局状态初始化和操作分发的集合)   |--demo1.js(demo1的数据)  -------------网店1 |--demo2.js(demo2的数据)  -------------网店2 |--index.js(全局数据集合)  --------------网店集合 |--store.js(全局数据的载体)   ---------------电商网站 |--App.jsx(根组件)  |--main.jsx(项目入口组件)   ---------------互联网 大概就是这么一个比喻,希望看客老爷们能理解我的这种比喻 某位大佬创建了一个电商网站,叫做四道(store).store里面可以创建很多网店,这些网店叫做瑞丢瑟斯(reducers).现在两个消费者,戴某1和戴某2,有两个店铺叫做demo1和demo2. 戴某1看上了demo1店铺的一件商品,情侣表,这个商品只有2件了,然后demo1就买了他,他将这个商品的接收地址分别发给了他自己和他对象那里,这个怎么买是他自己决定的,这个操作就是艾克神(action).因为戴某1买了这两件件商品,demo1店铺里面就没有这两件商品了.等到戴某2也想买这件商品的时候,发现这件商品已经空了.所以,店铺练得商品就是全局的数据or状态. ok了,上具体代码: 代码 redux/store.js // store构建方法 import {legacy_createStore,applyMiddleware} from redux// 支持异步 import thunk from redux-thunk// 开发工具 import {composeWithDevTools} from redux-devtools-extension// 所有的reducers import reducer from ./reducers// 将这些方法和参数组合,形成一个全局的store,store也是redux的核心 export default legacy_createStore(reducer,composeWithDevTools(applyMiddleware(thunk))) main.js import React from react import ReactDOM from react-dom/client import App from ./App.jsx import reset-css import ./index.css import store from ./redux/store.js import {Provider} from react-reduxReactDOM.createRoot(document.getElementById(root)).render(// React.StrictModeProvider store{store}App //Provider// /React.StrictMode, )redux/reducers/index.js import {combineReducers} from redux import demo1 from ./demo1 import demo2 from ./demo2//将会在store上暴露的模块 export default combineReducers({demo1,demo2 }) redux/reducers/demo1.js const initValue 0 export default function demo1(value initValue,action){console.log(action,点击了)const {type,data} actionswitch(type){case add:return valuedata;case delete:return value-data;default:return value} } redux/reducers/demo2.js //初始化的值 const initValue {name:王惊涛,age:27 }export default function demo2(valueinitValue,action){ const {type,data} action switch(type){case change:return datadefault:return value } } redux/actions/demo1Actions.js export const addAction data ({type:add,data}) export const deleteAction data ({type:delete,data}) export const asyncAddAction (data,time) {return (dispatch){setTimeout((){dispatch(addAction(data))},time)} } redux/actions/demo2Actions.js export const changeData data ({type:change,data}) src/pages/index.jsx import React, { Component } from react import withRouter from ../../utils/withRouter import Demo1 from ./demo1 import Demo2 from ./demo2 export default withRouter(class index extends Component {render() {return (divDemo1/Demo1hr /Demo2/Demo2/div)} })src/pages/demo1.jsx import React, { Component } from react import withRouter from ../../utils/withRouter import {connect} from react-redux import {addAction,deleteAction} from ../../redux/actions/demo1Actions import {Button} from antd const Demo1 withRouter(class index extends Component {addValue (){this.props.addAction(1)}deleteValue (){this.props.deleteAction(1)}render() {console.log(this.props,this.props---)return (divh4demo1页面/h4p原始操作值:{this.props.demo1}/pButton onClick{this.addValue}增加1/ButtonButton onClick{this.deleteValue}减少1/Buttonbr /pdemo2里面的内容:---- 姓名:{this.props.demo2.name} 年龄:{this.props.demo2.age}/p/div)} })export default connect(state ({demo1:state.demo1,demo2:state.demo2}),{addAction,deleteAction} )(Demo1) src/pages/demo2.jsx import React, { Component } from react import withRouter from ../../utils/withRouter import { connect } from react-redux import {changeData} from ../../redux/actions/demo2Actions import {addAction} from ../../redux/actions/demo1Actions import {Input,Button} from antd const Demo2 withRouter( class index extends Component {state {data:null}InputStype {width:400px}componentDidMount(){console.log(this.props,demo2中的props值)this.setState({data:this.props.demo2},(){console.log(this.props,this.props---demo2???)})}changeData (){this.props.changeData({name:马师,age:28})}addHandler (){this.props.addAction(1)}render() {return (divh4demo2页面/h4Button onClick{this.changeData}修改值/ButtonButton onClick{this.addHandler}增加值/Buttonp姓名:{this.props.demo2.name}/pp年龄:{this.props.demo2.age}/pbr /pdemo1里面的值:{this.props.demo1}/p/div)} })export default connect(state({demo1:state.demo1,demo2:state.demo2}),{changeData,addAction} )(Demo2)withRouter.jsx import {useLocation,useNavigate,useParams,} from react-router-dom;function withRouter(Component) {function ComponentWithRouterProp(props) {let location useLocation();let navigate useNavigate();let params useParams();return (Component{...props}router{{ location, navigate, params }}/);}return ComponentWithRouterProp;}export default withRouter 感觉有用的就给个赞吧,谢啦!
http://www.pierceye.com/news/496045/

相关文章:

  • jsp 网站开发教程多语言外贸网站建设
  • 免费销售网站模板下载安装济南网站制作推广
  • 青岛专业网站制作设计vs2008网站开发
  • 电子商务网站功能介绍0基础做网站用什么语言
  • 企业展示网站建设wordpress 优酷免广告
  • 濮阳做网站引导企业做网站
  • 卧龙区网站建设找做牙工作上哪个网站
  • 做网站的会计分录广州公司注册需要什么条件
  • 小米4路由器可以做网站嘛服务类网站建设服务公司
  • 电子商务网站建设规划书实例注册微信公众平台
  • 网站设计课程总结线上营销方案
  • 谷城网站建设网站集群建设实施方案
  • 怎么做外贸生意谷歌seo服务
  • 做网站好还是做淘宝好市场调研模板
  • 网站做换肤做一个平台费用是多少
  • 省内注销二建 建设部网站更新慢网站建设合同书封皮
  • 天津城市建设网站营销型网站的好处
  • 网站建设维护文档好看的页面
  • 网站搜索优化官网网站建设在电子商务中的作用的看法
  • 网站推广费用价格html大屏展示模板
  • 编辑网站用什么软件网站开发人员职责
  • 网站搜索引擎提交wordpress发布站点
  • 阳春网站建设天水网站seo
  • 仙桃市建设局网站wordpress链接前面的图标
  • 温州市城乡建设建档案馆网站公司装修费用可以一次性入账吗
  • 房地产开发公司网站宠物网页设计模板
  • 网站备案信息可以改吗中国做二手房最大的网站
  • 设计 企业网站罗湖网站-建设深圳信科
  • 太原自助模板建站手机版电脑qq登录入口
  • 公司网站建设哪家比较好app 网站