data:image/s3,"s3://crabby-images/595b9/595b93960a85cc667ce8fd08d02bc93846d53027" alt="深入理解React Router:从原理到实践"
上QQ阅读APP看本书,新人免费读10天
设备和账号都新为新人
2.3.4 history.createHref
createHref方法可将location对象转换为对应的URL字符串,在React Router源码中使用到了该方法,如在7.1.2节中,Link组件内部使用createHref方法创建a标签的href属性值。由于该方法为history对象的一个属性,所以开发者也可通过history.createHref使用该方法。
在使用hashHistory.createHref方法时,注意createHref不会对原字符串做任何编解码处理:
data:image/s3,"s3://crabby-images/ef6aa/ef6aa629bda66cc20343c3a1aa88019c3e3556e0" alt=""
并且hashHistory的createHref会判断HTML文档流中是否有href属性的base元素,其源码实现如下:
data:image/s3,"s3://crabby-images/905db/905dbcf1cc13200a1fc77ce7d1772f3237ac8253" alt=""
data:image/s3,"s3://crabby-images/6626b/6626b9838b37b737a9d2923786b1f29e40dfcb01" alt=""
在文档流中没有base元素的情况下,调用history.createHref创建路径,得到的字符串将以“#”开头:
data:image/s3,"s3://crabby-images/078a5/078a51046cdbf14d84e07868735523e9ccc51d2d" alt=""
如果文档流中有base元素且href有值(任何值均可),假设当前路径为/foo/baz,则调用history.createHref会得到:
data:image/s3,"s3://crabby-images/d462a/d462ad716714493f57864336e2a463a18e0e50ab" alt=""
此种情况将会得到包括浏览器pathname的完全的href路径。
由于在有base元素的情况下需要使用完全的路径设置到a标签的href属性上,才能使得浏览器识别出该a标签是否被访问过,因此,createHref源码才需要判断文档流中的base元素并拼接出全路径,以便正确设置a标签的属性值。