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

福州专业做网站免费找客户网站

福州专业做网站,免费找客户网站,wordpress 主题 破解,仪征建设局网站在 HTML5 的 History API 中,pushState 和 replaceState 方法也可以接受一个 state 对象作为参数。这些方法允许你在改变浏览器路由时不重新加载页面,并且可以附加一些自定义数据。 state 返回在 history 栈顶的 任意 值的拷贝。 let currentState h…

在 HTML5 的 History API 中,pushState 和 replaceState 方法也可以接受一个 state 对象作为参数。这些方法允许你在改变浏览器路由时不重新加载页面,并且可以附加一些自定义数据。

state

返回在 history 栈顶的 任意 值的拷贝。

let currentState = history.state;

结合router.push 方法来实现导航并传递状态

    router.push({path: '/xxx', state: {userId: '123', token: 'abc123'}});

存储和修改的状态对象

pushState

向浏览器的会话历史栈增加了一个条目。

pushState(state, unused)
pushState(state, unused, url)
  1. state:一个JavaScript对象,表示新的历史状态。这个对象可以包含任意的数据,用于保存页面的状态信息。
  2. title:新的历史记录的标题,但大多数浏览器忽略这个参数。
  3. url:新的历史记录的URL,可以是相对URL或绝对URL,但不能跨域。
history.pushState({page: 1}, "Page 1", "/page1");
// 这将添加一个新的历史记录,URL为/page1,状态对象为{page: 1}。
// 假设当前的 history.state 是这样的
const currentState = history.state || {};// 获取时间的值
const Time = time.value;// 创建新的 state 对象
const newState = {...currentState,  // 保留当前的 stateTime: Time ,
};// 使用 history.pushState 更新 state 并添加新条目
history.pushState(newState, document.title);

replaceState

使用状态对象和 URL 作为参数来修改当前的历史记录条目。

replaceState(state, unused)
replaceState(state, unused, url)
  1. state:一个JavaScript对象,表示要替换的历史状态,状态对象可以是 null
  2. title:新的历史记录的标题,但大多数浏览器忽略这个参数。
  3. url:替换后的URL,不能跨域。

使用demo

// 假设当前的 history.state 是这样的
const currentState = history.state || {};// 获取时间的值
const Time = time.value;// 创建新的 state 对象
const newState = {...currentState,  // 保留当前的 stateTime: Time ,
};// 使用 history.replaceState 更新 state 而不改变 URL
history.replaceState(newState, document.title);

锚点导航附带信息

function scrollToSection(sectionId, additionalData) {window.location.hash = sectionId;// 存储额外的状态信息window.sessionStorage.setItem(`section-${sectionId}-state`, JSON.stringify(additionalData));
}scrollToSection('#about-us', { timestamp: Date.now(), scrollPosition: window.scrollY });// 监听 hashchange 事件以恢复状态
window.addEventListener('hashchange', () => {const currentHash = window.location.hash.substring(1);const storedState = sessionStorage.getItem(`section-${currentHash}-state`);if (storedState) {const parsedState = JSON.parse(storedState);console.log('Restoring state for section:', currentHash, parsedState);// 执行相应的操作}
});

更多学习

History:pushState() 方法 - Web API | MDN

History:replaceState() 方法 - Web API | MDN

http://www.yayakq.cn/news/844254/

相关文章:

  • 有没有专业做淘宝网站wordpress交流插件
  • 怎么做彩票网站的代理上海seo外包
  • 建设部网站资质公示网站页面设计报告
  • 网站模板有什么用重庆企业
  • 怎么建设国字形网站河南郑州网站制作公司
  • 铁道部建设监理协会网站广东建设厅官网证件查询
  • 重庆网站建设推广服务做网站增加流量
  • 晋城网站建设电话图片转二维码在线制作生成器
  • 响应式网站是个坑广告投放方案
  • 系部网站开发项目的目的嘉兴网红桥在哪里
  • 益阳网站建设方案做网签合同的网站是
  • 天马网络 网站建设泰安人才市场最新招聘信息
  • 如何做百度网站推广wordpress lens
  • 团队如何分工做网站织梦网站源码
  • 学校网站建设的意义东莞全网seo排名优化中心
  • 网站开发前端应用程序免费影视app软件推荐
  • 外包网站开发公司网页设计网站怎么放到域名里
  • 智能建站系统 网站建设的首选儿童玩具商城网站建设
  • 做百度网站好吗微商城开发报价
  • 网站的开发工具有哪些最全的提交网站入口大全
  • 网站开发 外包网站建设教程简笔画
  • 大型网站开发 框架互联网营销师怎么报名
  • 网站上的图片怎么替换网站地图有哪些网址
  • 深圳制作网站培训学校网站footer设计
  • 十大免费网站免费下载软件ui设计好找工作吗?
  • 客户买东西返利网站怎么做科技节小发明小制作
  • 网站建设基本标准阿里云wordpress优化
  • 太原cms建站系统响应式网站建设品牌全网天下
  • 济南网站建设0531sosowordpress 医院
  • 做博客的网站有哪些常见的网站结构有