React 海淘商城

这次花了大半个月的空闲时间,终于完成个人项目—weinihaigou-react。仅以此文,来记录一下我写这个项目的感想以及总结。

1.技术杂

我用的技术杂是react^16.0.0 + react-router^ 4.2.0 + redux^ 3.7.2 。开发脚手架是create-react-app。

2.项目介绍

这是一个SPA的海购商城,此项目大大小小共 16 个主体页面,涉及注册、登录、商品详情、购物车、下单、订单、订单详情等等,是一个完整的流程。一般公司即便是官网的单页面项目都没这么复杂,如果这个项目能驾驭的了,相信大部分公司的其他单页面应用也就不在话下,即便更复杂,也不会比这个高到哪里去。(做了控制,不能在该项目付款)

3.资源划分

因为之前都是做多页面的,所以转做单页面,遇到的第一个问题就是如何划分资源。比如之前我是在一个项目里面有js文件夹,css文件夹,html文件夹,每个主文件夹下面还会有子文件夹。做SPA,我感觉也是按照页面来分,不过要细入拆分成组件,比如首页下面有一个固定的页脚,分类页面下面也有一个相同固定的页脚,那么就可以提出来作为一个comFooter组件(我写组件的原则就是现在或者将来有可能用到2次或者以上)。那么就会有一个components文件夹,用来专门放置组件的。其次每个页面还是要放在一个pages文件夹下面(也是以组件形式的)。然后做SPA离不开的就是路由以及状态管理器(这个简单的可以不用的),那么又多出来了一个router文件夹以及vuex文件夹。根据上面的分析,我在src文件夹下面的资源配置如下图所示:


4.个人体会

这一段注定很杂乱但是却是本次开发的精华所在。

很多新手和本胖一样不知道如何做第一步,感觉有很多东西都要做,那么就慢慢来。比如本胖这次就是先写好store的骨架以及router的骨架以及main.js和App.vue,这样你的项目以及可以跑起来了。然后根据页面一个一个来,每次写一个页面组件都往router添加一个路由以及看这个页面组件是否有可以提取的组件,有的话就往components文件夹里面添加一个对应的组件,然后在相应的页面组件引用就可以了。慢慢地你的router以及store就会丰满起来。

这次的react项目完全是为了学习react而写的。由于之前本写过一个vue海淘商城,所以下面对react以及vue做一个项目比较吧。

路由配置:

react里面要用Router以及Route来指定相应的路由,vu里面只是一个json格式。还要注意在vue里面只用resolve=>require(['../pages/goods/goodsResult.vue'], resolve)就能懒加载组件,在react-router4以上版本,本胖自己写了一个懒加载组件asyncComponent,所有要懒加载的组件都要通过这个懒加载组件去调用。下面是react以及vue的路由配置图。



store管理:

2者差不多,都是有action,reducer/mutations,store。不过,react你想在组件里面引用store里面的值要每个组件都手动导入store,没有想vue那样全局注册机制(这一点,好的地方在于react的纯粹性,毕竟项目不是你一个做,vue的话很多东西都可以在全局引入,方便了你自己,但是对于整个项目是有污染的)

其他的就是感觉从vue迁移到react,你需要写很多this.state,this.setState(),其中this.setState()这个方法,首先他是异步的,还有一个回调函数,其次,如果你需要改state里面的一个对象的属性或者属性的属性,那么需要定义一个中间对象,先给这个中间对象赋值成你要改成的对象,然后去改成这个中间对象后再将改变后的中间对象setState才行。

react 海淘商城

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 219,701评论 6 508
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 93,649评论 3 396
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 166,037评论 0 356
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,994评论 1 295
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 68,018评论 6 395
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,796评论 1 308
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,481评论 3 420
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,370评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,868评论 1 319
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 38,014评论 3 338
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 40,153评论 1 352
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,832评论 5 346
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,494评论 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 32,039评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,156评论 1 272
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,437评论 3 373
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 45,131评论 2 356

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 172,196评论 25 707
  • 谭总带领前台美女海底捞聚餐 海底捞开餐前大家干一杯,2015年大家工作辛苦了!祝公司业绩蒸蒸日上,同事们身体健康,...
    柠檬公主阅读 529评论 0 0
  • 最近接触很多MMM传销,以前知道这个组织,也一直没明白到底是什么情况。今天去谷歌搜到了这家网站,感觉亮点是里面的教...
    闻舒阅读 275评论 0 0