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

网站无搜索结果页面怎么做网络工程师考试时间

网站无搜索结果页面怎么做,网络工程师考试时间,花灯制作,网站建设与管理基础文章目录 1. Hash模式#xff1a;简洁而广泛适用2. History模式#xff1a;更自然的用户体验3. 结论 在现代Web开发中#xff0c;单页面应用#xff08;Single Page Application#xff0c;简称SPA#xff09;因其流畅的用户体验和高效的页面交互能力而备受青睐。前端路由… 文章目录 1. Hash模式简洁而广泛适用2. History模式更自然的用户体验3. 结论 在现代Web开发中单页面应用Single Page Application简称SPA因其流畅的用户体验和高效的页面交互能力而备受青睐。前端路由作为SPA的核心技术之一允许用户在不刷新整个页面的情况下通过URL的变化来加载和切换不同的页面内容。本文将通过手写代码的方式深入探讨前端路由的两种主流实现方式Hash模式和History模式。 1. Hash模式简洁而广泛适用 Hash模式利用URL的哈希#之后的部分来存储路由信息由于哈希的变化不会触发完整的页面刷新因此非常适合于实现SPA的前端路由。下面是一个使用Hash模式的手写路由实现示例 !-- HTML结构 -- nav idnavullia href#/page1Page 1/a/lilia href#/page2Page 2/a/li/ul /nav div idcontent/divclass HashRouter {constructor() {this.routes {};window.addEventListener(hashchange, this.load.bind(this), false);this.load();}register(path, callback) {this.routes[path] callback;}load() {let hash window.location.hash.slice(1);let handler this.routes[hash] || (() {});handler.call(this);} }let router new HashRouter(); router.register(/page1, () document.getElementById(content).innerHTML Page 1 Content); router.register(/page2, () document.getElementById(content).innerHTML Page 2 Content);在这个示例中我们监听hashchange事件每当URL的哈希部分发生变化时都会触发load方法根据当前的哈希值加载相应的内容。Hash模式的一个主要优点是它的广泛兼容性几乎所有的浏览器都支持哈希的变化。 这里有一个细节就是使用bind来“绑定”this值 当你在事件监听器中直接使用this.load在事件触发时this的值会根据调用上下文来决定通常在这种情况下this会指向事件发生的元素比如window对象因为在hashchange事件中this通常指的是window。这可能会导致你的load方法无法访问到HashRouter或HistoryRouter实例的属性和方法因为this不再指向你期望的实例。 为了避免这个问题使用bind方法来“绑定”this值确保无论load方法在哪里被调用其内部的this都会指向HashRouter或HistoryRouter的实例。这样load方法就能正确访问和操作实例上的属性和方法如this.routes和this.load方法自身。 简而言之使用this.load.bind(this)是为了确保load方法的this上下文正确无误使其能够访问到所在类实例的成员从而正确执行路由逻辑。如果不使用bindthis可能会指向错误的对象导致方法无法按预期工作。 2. History模式更自然的用户体验 History模式利用HTML5的History API包括pushState, replaceState和popstate事件来管理浏览器的历史记录。相比于Hash模式History模式能够提供更加自然的URL结构没有显眼的#符号使URL看起来更像是传统的多页面应用。说多了就是少个#让人觉得更好看一点 !-- HTML结构 -- nav idnavullia href/page1Page 1/a/lilia href/page2Page 2/a/li/ul /nav div idcontent/divclass HistoryRouter {constructor() {this.routes {};window.addEventListener(popstate, this.load.bind(this), false);this.load();}register(path, callback) {this.routes[path] callback;}load() {let path window.location.pathname;let handler this.routes[path] || (() {});handler.call(this);}navigate(path) {history.pushState({}, , path);this.load();} }let router new HistoryRouter(); router.register(/page1, () document.getElementById(content).innerHTML Page 1 Content); router.register(/page2, () document.getElementById(content).innerHTML Page 2 Content);document.querySelectorAll(#nav a).forEach(link {link.addEventListener(click, (e) {e.preventDefault();router.navigate(e.target.href);}); });在History模式下我们通过监听popstate事件来捕获URL的变化并通过pushState方法来改变当前的URL同时保持页面不刷新。这里这种history方法可能会受到file://协议的限制导致pushState代码运行不了。最推荐的方法是在本地搭建一个HTTP服务器来运行你的项目而不是直接打开.html文件。这样可以绕过file://协议的限制。如果你使用的是vs code的呢就右键文件通过open with live server方法打开这个功能允许你快速启动一个轻量级的HTTP服务器用于预览和测试你的HTML、CSS和JavaScript代码而无需手动配置服务器环境。 3. 结论 无论是Hash模式还是History模式每种方法都有其独特的优缺点。Hash模式易于实现且兼容性好而History模式则提供更美观的URL和更自然的浏览体验。在实际项目中根据应用的具体需求和目标用户群体选择合适的前端路由模式至关重要。通过手写代码实践我们不仅能加深对这两种模式的理解还能更好地掌握如何在真实项目中灵活运用前端路由技术。
http://www.dnsts.com.cn/news/69947.html

相关文章:

  • 南通网站定制搭建自己网站建设的流程是什么
  • 都有什么公司需要网站建设做盗链电影网站怎么样
  • 信阳建设监理协会网站机关网站源码
  • 微信公众号涨粉 网站wordpress页面改风格
  • 天津手机网站建设制作dedecms5.7装饰网站模板
  • 怎么做一个自己网站销售的三个核心点
  • 有什么做网站的公司南昌师范学院网站建设的意义和目的
  • 单页网站快速收录汽配外贸怎么找客户
  • 国外网站空间租用哪个好宜昌网站制作公司亿腾
  • 外国的网站 ftp优化搜狐的培训
  • 做网站什么类型好百度网站推广价格查询
  • 作风建设提升年活动网站国外的wordpress主题公园
  • 学院网站建设服务宗旨河南建设工程信息网 建议访问中项网
  • 展示网站模板下载长沙3合1网站建设公司
  • wordpress定义小工具栏长沙搜索排名优化公司
  • 房产公司网站建设中国万网域名注册官网
  • asp网站一打开就是download网站长尾关键词排名软件
  • 海口建网站 模板网站搭建工作室加盟
  • 网站制作需求链接买卖
  • 全景网站开发待遇工程网站模板
  • 类模板模板下载网站有哪些内容找公司做网站要注意什么
  • 建筑网站官网网络科技公司有什么职位
  • linux网站服务器配置东莞横沥理工学校
  • 合肥网站开发 合肥网站优化内蒙古自治区精神文明建设网站
  • 做网站优化两年遇到的SEO常态企业网络推广公司
  • 福州有网站开发的公司吗青岛注册公司网站
  • 网站备案时长国外ip代理
  • 教育考试类网站建设开发一个平台要多少钱
  • 英文版网站建设方案北京市建设监理协会网站
  • 网站建设技术工具wordpress私活