LMLPHP后院

JavaScript实现图片懒加载非可视区域延迟加载

要加载这么多的资源,给用户感觉网站非常慢。大部分的网站都是小网站,流量都很小,网站也都是运行在虚拟主机上,这样一来,JQuery 放在自己的站点上流量耗费很大;使用免费的 CDN 也通常不太稳定,并且浏览器得重新解析新的域名,网站速度自然上不去。 在这种情况下,LML 团队打造的开源 JavaScript 框架 LMLJS 很好的解决了这个问题,LMLJS 现在体积大小约为5KB,压缩后大概2KB。L...

如何通过服务端HTTP头解决前端跨域问题

首先,HTTP 跨域问题的产生,并不是服务端的行为。是 Web 的规定,并且各大浏览器厂商都遵守了这个规则。其次,要完全通过服务端解决跨域问题是做不到的,至少不是所有浏览器都有效,IE 系列内核的浏览器就不支持。所以,HTTP 跨域要完美的解决是很难的。为什么我写这篇文章,其实这种问题,一般人不太关注,或者也尽量避免这个问题。原因是现在开发的前后端分离导致很多前端开发完全脱离了后端,而又懒得搭建环境,...

小米自带浏览器网页跳转到sdfste.com/njs.php

深夜了,本来想早点睡个觉的,用小米手机自带浏览器访问网站 www.lmlphp.com 和 blog.lmlphp.com 都跳转到了 www.sdfste.com/njs.php?http://www.lmlphp.com 和 www.sdfste.com/njs.php?http://blog.lmlphp.com。然后浏览器头部出现那个红色的警告,此网站可能存在风险,请谨慎访问! 我大吃一惊,...

谈谈HTML网页编辑器技术实现

 ,就一定明白,国内的产品都做的很烂很烂的,当然微信出现空白实体是因为各部门协调不一致造成的,跟编辑器没有关系。再啰嗦一点,其实 HTML 和 DOM 本身是不太适合做编辑器的,要兼容老的浏览器就非常的困难,于是产生了很多的黑技术。在我看来,兼容老的 IE 系列是没有意义了,但兼容现代浏览器还是很容易的事情。先谈一谈 Selection获取 selection 对象非常简单,如下所示:ge...

LMLPHP官方网站已经全站支持HTTPS

类似百度分享这样的插件,这样的外部 JavaScript 一般不支持 HTTPS,所以为了让网站能正常的 HTTPS 化,这样的东西必须去除。如果不去除的话,像 Chrome,Firefox 这些高等浏览器都直接打叉叉,导致浏览器的 HTTPS 绿色标签很难看。 关于图片连接问题,图片连接最好是本站的,如果不是本站的资源,也尽量在网站建设的时候不要明确写清使用的协议,A 标签中使用 // 作为地址前缀...

HTML5 history API改变浏览器地址无需hash和刷新加载页面

现在很多网站的前端做的非常炫,点击某个链接瞬间改变浏览器的地址栏的地址,改变的方式不是使用锚点,而是直接改变 URL,页面稍后局部加载完成。如果直接复制页面地址在新的浏览器选项卡中打开则是全部加载整个页面。这样的前端技术体验,一开始让我和很多的前端工程师觉得现有的知识不可能做到。后来才了解到,在一般的比较老的浏览器中是不可能实现的,需要在 Chrome, Safari, FF4+, and IE10...

Chrome插件在高版本浏览器中安装报错解决

去年过年前开发的Chrome浏览器插件,昨晚在我自己的笔记本上测试没有问题,今天来公司一安装就连续出现了很多的报错,下面将错误和解决方案记录如下,相信有不少的网友会碰到类似的问题。首次安装报错如下: Could not load extension from 'G:\...'. The manifest_version key must be present and set to 2 (withou...

前端开发之CSS兼容写法经验总结

以至于很多东西懂了又忘记,忘记了又知道了。最近的一段时间,我在写LMLPHP框架同时完成官网和博客等其他项目的开发,才发现总结的重要性。下面将例举一些CSS书写需要注意的一些问题,这些问题都是本人在做浏览器兼容的时候发现的,非常重要。对于前端工程师们来说,也许值得一看,欢迎有志之士留言交流。前端CSS之图片边框一个人只有从头至尾完成整个WEB项目时,且在不使用外界UI框架时,一定会知道,我们在定义全局...

图片格式或后缀名与浏览器的关系

本文谈谈关于图片后缀名的问题,以及图片格式,图片后缀名和浏览器或者 Windows 照片查看器等图片编辑查看软件的关系。事实证明,png bmp jpg gif 后缀结尾的图片不论格式是否与之对应,浏览器和 Windows 照片查看器都能正常打开。浏览器能正常打开是因为 web 服务器能正确识别图片并返回正确的协议头;照片查看器能正常打开也是同样的原因,靠的不是后缀名。写这篇文章是因为我在代码中看到上...

Ajax跨域原理JQuery之Jsonp使用剖析

change 注册事件,然后再执行 open 和 send 方法。一般来说,实现简单的Ajax请求,我们只需要在 readyState 等于 4(请求完成) 之后再进行后续的状态码判断并处理。对于IE浏览器,实现起来稍有不同,IE系列是使用 ActiveXObject 控件来实现异步请求的,不同版本的IE浏览器在写法上稍有不同,因此完整的Ajax类需要对IE系列浏览器做个判断,不过IE11之后已经不再...
2020-05-25 10:15:28 1590372928 0.047160