什么叫单页面开发_获取当前页面url

什么叫单页面开发_获取当前页面url参考网址https://www.cnblogs.com/belongs-to-qinghua/p/11151054.htmlhttp://www.zhiliaotang.net/jishujiaoliu/web/965.html单页面开发:单页面开发常用于webapp开发和后台管理系统等单页面应用原理:我们通常所说的单页面应用程序通常是通过前端框架vue,react,angular…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE稳定放心使用

参考网址
https://www.cnblogs.com/belongs-to-qinghua/p/11151054.html
http://www.zhiliaotang.net/jishujiaoliu/web/965.html

单页面开发:
单页面开发常用于webapp开发和后台管理系统等
单页面应用原理:

我们通常所说的单页面应用程序通常是通过前端框架vue, react, angular进行开发,单页面程序将所有的活动局限于一个web页面中,仅在该web页面初始化时加载相应html,js和css,一旦页面加载完成,spa不会因为用户的操作而进行页面的重新加载或跳转,而是利用js动态的变换html的内容,从而实现ui与用户的交互,由于避免了页面的重新加载,spa可以提供较为流畅的用户体验

简单理解就是:
第一次进入页面时会请求一个html文件,刷新点击一下会切换到其他组件,此时路径也会相应的改变,但是并没有新的html文件的请求,原理是:
js会感知到url的变化,通过这一点,可以用js动态的将当前的页面内容清除掉,然后将下一个页面的内容挂载到当前页面上,就是所谓的路由,通过路由判断页面应该显示的组件,这种过程就是单页面应用,每次跳转不请求html文件,而是通过路由跳转来渲染组件

优点:

  • 页面切换快,良好的交互体检,因为每次切换页面时,不需要重新加载整个页面,不需要做html文件的请求,这样就节约了很多http发送时延,获取数据也是通过ajax异步获取,没有页面之间的切换,就不会出现白屏现象,也不会出现假死并有闪烁现象,页面显示流畅
  • 良好的前后端分离模式,后端不再负责模版渲染,输出页面工作,即同一套后端程序代码,不用修改就可以用于web界面,手机,平板等多种客户端
  • 减轻服务器压力,单页面相对服务器压力小,服务器只用于输出数据就可以,不用管展示逻辑和页面合成。吞吐能力会高好几倍

缺点

  • 首屏加载慢
    • 如果不对路由进行处理,在加载首页的时候,就会将所有组件全部加载,并向服务器请求数据,这就会拖慢加载速度
    • 通过查看network,发现整个网站加载时长长达十几秒,加载时间最长的就是js,css,图片

解决方案:

  • vue-router懒加载

    • vue懒加载就是按需加载,只有当路由被访问时才会加载对应的组件,而不是在加载首页的时候就加载,项目越大,对首屏的速度提升就越明显
      在这里插入图片描述
  • CDN加速
    – 在做项目时,我们会用到很多库,采用cdn加载可以加快加载速度

  • 服务器渲染, 服务器渲染还能对seo优化起到作用,有理由搜索引擎抓取更多游泳信息,如果页面纯前端渲染,搜索引擎抓取到的就只是空页面

不利于seo
seo本质就是一个服务器向另一个服务器发请求,解析请求内容,但是搜索引擎是不会去执行请求到的js的,也就是说搜索引擎的基础爬虫的原理就是抓取url,然后获取html源代码并解析,如果一个单页应用,html在服务器还没有渲染部分数据,在浏览器才渲染出数据,即搜索引擎请求的html是模型页面而不是最终数据的渲染页面,这样就很不利于内容被搜素引擎搜索到
seo效果差,因为搜索引擎只认识html的内容,不认识js的内容,而单页面应用的内容都是考js渲染生成出来的,搜索引擎不识别这部分内容,所以就不会给一个好排名,导致单页面应用做出来的网页在百度和谷歌上的排名差

解决方法:

  • 服务端渲染, 服务器合成完整的html问价再输出到浏览器
  • 页面预渲染
  • 路由采用h5的 historty模式

不适合开发大型项目
大型项目可能会涉及大量的dom操作,复杂的动画效果,也就不适合vue,react框架开发

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/182376.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • pycharm好用的主题_pycharm关联python

    pycharm好用的主题_pycharm关联python所谓工欲善其事,必先利其器;在我们日常开发中,长时间编码从眼睛上心里承受压力上有个好的视觉感觉是很加分的以下是我个人十分喜欢的pycharm主题风格,包含整体风格/字体/背景颜色/背景图片;其设置如下:01主题:pycharm的File->Settings->Plugins,搜索MaterialThemeUI并安装,安装之后进行restart02字体:File…

    2022年8月26日
    8
  • phpstorm鼠标显示问题

    phpstorm鼠标显示问题

    2021年10月17日
    94
  • 关于模板函数声明与定义的问题[通俗易懂]

    c++primer上说:c++模板函数的声明与定义通常放在头文件中,而普通的函数通常是声明放在头文件中,定义放在源文件中,为什么会有这样的区别呢?模板函数与普通成员函数到底有什么区别?测试代码:tem.h#ifndef_TEM_H#define_TEM_HtemplateTadd(Ta,Tb);//{//returna+b;//}

    2022年4月17日
    42
  • Poetry(1)Poetry介绍与安装

    Poetry(1)Poetry介绍与安装介绍Poetry是Python中的依赖管理和打包工具,当然它也可以配置虚拟环境。它允许您声明项目所依赖的库,并为您管理(安装/更新)它们。之前一直使用virtualenvwrapper管理虚拟

    2022年7月29日
    27
  • eXtremeDB内存实时数据库

    eXtremeDB内存实时数据库这是一款实时和嵌入式软件 用来管理持续增长的复杂数据 来支持高级应用的特性 性能和可靠性 更短的产品开发周期等需求 驱使开发者在他们的设计中 考虑采用经验证的 成熟的商业数据库系统组件来 来满足应用层的这些需求 McObject 公司的 eXtremeDB 嵌入式数据库系列产品是将高性能 稳定性和简单易用性等特性同时融入了工业基的数据库引擎 了解 eXtremeDB 产品系列或 eXtreme

    2025年8月23日
    0
  • C/C++指针参数赋值问题

    C/C++指针参数赋值问题

    2021年11月20日
    41

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号