什么叫单页面开发_获取当前页面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)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • js layui 弹出子窗体_Layui弹出层 加载 做编辑页面的方法[通俗易懂]

    js layui 弹出子窗体_Layui弹出层 加载 做编辑页面的方法[通俗易懂]layui是一款优秀的模块化前端框架。利用layui弹出层做编辑页面先上效果图基本准备,引入layui的layui.css,layui.js文件Js方法/***页面内弹出编辑窗口//需要引入layui.jslayui.css文件*@param{}title标题不显示为false*@param{}area大小[“400px”,”500px”]或者”400px”—&…

    2022年5月16日
    113
  • delphi7中idHTTP的使用

    delphi7中idHTTP的使用1.直接idhttp:Tidhttp声明一个var变量是不能使用的。必须有控件2.使用IdHTTP调post接口,xml格式IdHTTP1.HandleRedirects:=True;//允许头转向IdHTTP1.ReadTimeout:=30000;//请求超时设置IdHTTP1.HTTPOptions:=IdHTTP1.HTT…

    2022年7月15日
    55
  • PSCU选择Qlik支持其完善的服务交付战略「建议收藏」

    PSCU选择Qlik支持其完善的服务交付战略

    2022年4月2日
    77
  • mysql倒序截取字符串_MySQL数据库之mysql截取字符串与reverse函数

    mysql倒序截取字符串_MySQL数据库之mysql截取字符串与reverse函数本文主要向大家介绍了MySQL数据库之mysql截取字符串与reverse函数,通过具体的内容向大家展现,希望对大家学习MySQL数据库有所帮助。这个网页上很多知识点,可以学习下,关于mysql的函数,也可以作为API查询:这里只说下mysql的截取函数和reverse函数:MySQL字符串截取函数:left(),right(),substring(),substring_index()…

    2022年10月31日
    0
  • c花体复制_花式字体大全可复制 花式字体转换器「建议收藏」

    c花体复制_花式字体大全可复制 花式字体转换器「建议收藏」求可复制花体字?1、windows系统的字体文件都放在这个文件夹下:C:\WINDOWS\Fonts,首先打开此文件夹。2、虽然在此文件夹下右键单击字体文件的菜单中无复制粘贴功能,但是却能使用“复制”快捷键,导出字体文件的方法也就是选中所要导出的字体文件,“Ctrl”“C”(复制快捷键),然后再粘贴到目标文件夹就好了。有好心人发一下英文字母h的花式字体吗,谢谢了,要可以复制的,小写的?这与字体有…

    2022年4月29日
    1.2K
  • 批处理for命令的用法_cmd批处理命令

    批处理for命令的用法_cmd批处理命令摘自WindowsXP的帮助文档。For对一组文件中的每个文件运行指定的命令。语法for{%variable|%%variable}in(set)docommand[CommandLineOptions]参数{%variable|%%variable}必需。代表可替换的参数。使用%variable通过命令提示符执行for命令。使用%%variable在批处理文件中执行for命令。变量要区分大小写,并且必须用Alpha值表示,例如,%A、%B或%C。.

    2022年10月12日
    0

发表回复

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

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