React(脚手架)——create-react-app撸api
2019-03-11 本文已影响0人
感觉不错哦
传值其实本质还是只有一个,就是获取query!获取query的方式不一样,最常见的就是获取url参数数据,当然也有通过缓存比如说localstorage或者cookie
动态路由
data:image/s3,"s3://crabby-images/11912/11912fd2e6398a176e4930e3956f2418c3dcd0c7" alt=""
新建一个组件,并且已经配置好了 路由
data:image/s3,"s3://crabby-images/efa76/efa7635bc0be05141aad6701b6c1af5116cdeb05" alt=""
现在我们编辑之前一个写过的路由,并且让他跳转
data:image/s3,"s3://crabby-images/5d7dd/5d7dd644a9f238c89c5d7e336e2276444c58c811" alt=""
注意我在这个组件中使用了Link,那么我们就要在上方引入这个Link,这步很重要
data:image/s3,"s3://crabby-images/cdd02/cdd02e1209058e933a73602706b6793d3afe1b38" alt=""
此时点击按钮自然而然的就跳转到了content组件页面,OK此时我们想获取点击的同时获取aid
有vue或者是node基础的小伙伴应该晓得了动态路由怎么配,就是:xxx
data:image/s3,"s3://crabby-images/70936/70936ec56847725a1ced22ea58b0613b454e34d6" alt=""
在/content后方加上:参数即可,当然这是路由的配置,传参的配置还没好,既然是变量,那我们在传参的时候to里面应该就是{}表达式
data:image/s3,"s3://crabby-images/6e2cb/6e2cb4d99c18d5ec4c9b09b2efe0852ad2f947a6" alt=""
此时再点击链接的时候,url上就出现了对应的aid
data:image/s3,"s3://crabby-images/e7f05/e7f05ce005c46848e0d792b941cfb4b0079705a8" alt=""
那当然这样写不推荐,推荐ES6的模板字符串
data:image/s3,"s3://crabby-images/eed47/eed4739cb4155cbd7a765dfd18adcc81a09b98e7" alt=""
OK~~~
如何获取参数呢,我们可以在Content的生命周期函数中打印一下
data:image/s3,"s3://crabby-images/c718c/c718c4e92d2a718c2f824141ca70a10a92a318f3" alt=""
data:image/s3,"s3://crabby-images/c57db/c57dba32f85056accb527f91bbb17cc65a938a5b" alt=""
当然这个参数不是传参决定的是路由配置的时候决定的
data:image/s3,"s3://crabby-images/986a4/986a4414a010747bd667994a1c2886d76c98d9a1" alt=""
如果这里改变了一下那么key就变成bid了
get传值
get传值用的也比较广泛完全看自己个人喜好,get传值其实就是获取url中的数据,就像平时URL的location.search
data:image/s3,"s3://crabby-images/bfe2b/bfe2b39f45ecd536271f68c3479ed53766825cd9" alt=""
把配置搞回原样,然后在Link中添加参数
data:image/s3,"s3://crabby-images/f9a83/f9a834fccdf299c58d80cca2d9d236a57e3847bd" alt=""
那么这时候数据就会在URL中显示出来
data:image/s3,"s3://crabby-images/bbe42/bbe424b47f642938c4dced99f2df3f47708e1de5" alt=""
此时处理的方法就有很多了,你可以直接使用原生JS的window.location.search方法处理,也可以使用react
data:image/s3,"s3://crabby-images/bd80c/bd80c699f83f76b3c1a469b7a0b666219cb7cbc7" alt=""
此时控制台就会打印 ?aid=2
如何处理这个,方法很多,比如写个原生的写法
data:image/s3,"s3://crabby-images/1eb57/1eb57c843f4d815bfa2cb8260b9b752b86bbd050" alt=""
data:image/s3,"s3://crabby-images/6cbd6/6cbd6c2da2bb25e24fe0cbd552642ba13f6d9821" alt=""
如果说参数多的话,这种方法就会很麻烦。那熟悉node的小伙伴肯定知道url是可以解析这种域名的
data:image/s3,"s3://crabby-images/1dd7f/1dd7fd0a0a769bdd6d36630b058fceadae21946e" alt=""
通过es5的方法引入url,然后使用url.parse
data:image/s3,"s3://crabby-images/e9828/e9828a97a0ca6b33f40725307dfee0d7e6480637" alt=""
成功获取到参数,而且继续加参数也无所畏惧,当然你用react也是一样的
data:image/s3,"s3://crabby-images/37c86/37c86d7cb1053596b4e3547ddf181fe1c9958c65" alt=""
如果你不想让别人知道你传了啥,开启你的猥琐模式的话,可以使用下面这个方法
data:image/s3,"s3://crabby-images/679e3/679e3220d9449ef59719b42e48d5867d533fb5cb" alt=""
data:image/s3,"s3://crabby-images/edd2f/edd2fc063cfd51560116e5745f2776705ffcfd69" alt=""
data:image/s3,"s3://crabby-images/80f39/80f39d89c64f6bbcc56b4cfa9beb06408122754b" alt=""