纯CSS打造Chrome浏览器

简介: Mark Qin用HTML和CSS模拟了一个Chrome浏览器。Demo在此。都是一些基本的CSS3的使用,并不复杂。各位有兴趣地可以试着也写一个。唯一复杂的地方是浏览器标签的模拟。

Mark Qin用HTML和CSS模拟了一个Chrome浏览器

Demo在此

都是一些基本的CSS3的使用,并不复杂。各位有兴趣地可以试着也写一个。

唯一复杂的地方是浏览器标签的模拟。

image.png

可以看出,Chrome标签的基本特点如下:

  • 梯形
  • 有圆角
  • 宽度自适应

用图片可以轻松搞定,但是怎么能用图片呢?作为一个有追求的前端,肯定要用纯CSS3实现啊!

标签的HTML很简单:

<ul class="tabs">

   <li>新标签页</li>

   <liclass="selected">百度一下,你就知道</li>

   <li>新标签页</li>

</ul>

梯形的两端用:before:after 轻松搞定。

.tabsli:before,

.tabs li:after {

    width: 16px;

    height: 24px;

    content: " ";

    border: 1px solid #3b5c95;

}

处理定位的时候需要注意元素间的z-index关系。

.tabsli {

    display: inline-block;

    position: relative;

    z-index: 0;

}

.tabsli:before,

.tabsli:after {

    position: absolute;

    z-index: 3;

}

.tabsli:before {

    left: -12px;

}

.tabsli:after {

    right: -12px;

}

变形则使用CSS3的transform

.tabsli:before {

   -o-transform: skew(-22deg);

   -ms-transform: skew(-22deg);

   -moz-transform: skew(-22deg);

   -webkit-transform: skew(-22deg);

   transform: skew(-22deg);

}

.tabsli:after {

   -o-transform: skew(22deg);

   -ms-transform: skew(22deg);

   -moz-transform: skew(22deg);

   -webkit-transform: skew(22deg);

   transform: skew(22deg);

}

好了,差不多大功告成了。接下来还要稍微调整下,对照Chrome浏览器填充下渐变色,高度、宽度、位置也需要微调一下。

相关文章
|
7月前
|
前端开发
WebView2 控件(基于 Microsoft Edge (Chromium) 的嵌入式浏览器控件),保存资源(图片、脚本、CSS)
WebView2 控件(基于 Microsoft Edge (Chromium) 的嵌入式浏览器控件),保存资源(图片、脚本、CSS)
372 64
|
Web App开发 数据采集 存储
WebDriver与Chrome DevTools Protocol:如何在浏览器自动化中提升效率
本文探讨了如何利用Chrome DevTools Protocol (CDP) 与 Selenium WebDriver 提升浏览器自动化效率,结合代理IP技术高效采集微博数据。通过CDP,开发者可直接操作浏览器底层功能,如网络拦截、性能分析等,增强控制精度。示例代码展示了如何设置代理IP、cookie及user-agent来模拟真实用户行为,提高数据抓取成功率与稳定性。适用于需要频繁抓取互联网数据的应用场景。
1516 3
WebDriver与Chrome DevTools Protocol:如何在浏览器自动化中提升效率
|
Web App开发 JSON 安全
Chrome浏览器的跨域问题
【10月更文挑战第6天】
2574 123
|
Web App开发 人工智能 JSON
AutoMouser:AI Chrome扩展程序,实时跟踪用户的浏览器操作,自动生成自动化操作脚本
AutoMouser是一款Chrome扩展程序,能够实时跟踪用户交互行为,并基于OpenAI的GPT模型自动生成Selenium测试代码,简化自动化测试流程。
948 17
AutoMouser:AI Chrome扩展程序,实时跟踪用户的浏览器操作,自动生成自动化操作脚本
|
Web App开发 存储 前端开发
Chrome浏览器的跨域问题
Chrome浏览器的跨域问题
1019 128
|
Web App开发 数据采集 JavaScript
Chrome浏览器实例的TypeScript自动化脚本
Chrome浏览器实例的TypeScript自动化脚本
|
Web App开发 JavaScript 前端开发
使用 Chrome 浏览器的内存分析工具来检测 JavaScript 中的内存泄漏
【10月更文挑战第25天】利用 Chrome 浏览器的内存分析工具,可以较为准确地检测 JavaScript 中的内存泄漏问题,并帮助我们找出潜在的泄漏点,以便采取相应的解决措施。
1645 9
|
Web App开发 缓存 安全
WIN11 Chrome 双击打不开闪退及Chrome浏览器不能拖拽文件crx
【11月更文挑战第6天】本文介绍了 WIN11 系统中 Chrome 浏览器双击打不开闪退及不能拖拽文件 crx 的原因和解决方法。包括浏览器版本过旧、扩展程序冲突、硬件加速问题、缓存过多、安全软件冲突、系统文件损坏、用户配置文件损坏等问题的解决方案,以及 crx 文件的屏蔽、权限问题和文件格式问题的处理方法。
4349 2
|
Web App开发 Linux iOS开发
Chrome浏览器如何导出所有书签并导入书签
【11月更文挑战第4天】本文介绍了如何在 Chrome 浏览器中导出和导入书签。导出时,打开书签管理器,点击“整理”按钮选择“导出书签”,保存为 HTML 文件。导入时,同样打开书签管理器,点击“整理”按钮选择“导入书签”,选择之前导出的 HTML 文件即可。其他主流浏览器也支持导入这种格式的书签文件。
10956 2
|
Web App开发 开发者