常用的技术

1、精灵技术

精灵技术产生的背景

图所示为网页的请求原理图,当用户访问一个网站时,需要向服务器发送请求,网页上的每张图像都要经过一次请求才能展现给用户。

然而,一个网页中往往会应用很多小的背景图像作为修饰,当网页中的图像过多时,服务器就会频繁地接受和发送请求,这将大大降低页面的加载速度。为了有效地减少服务器接受和发送请求的次数,提高页面的加载速度,出现了CSS精灵技术(也称CSS Sprites、CSS雪碧)。

精灵技术本质

简单地说,CSS精灵是一种处理网页背景图像的方式。它将一个页面涉及到的所有零星背景图像都集中到一张大图中去,然后将大图应用于网页,这样,当用户访问该页面时,只需向服务发送一次请求,网页中的背景图像即可全部展示出来。通常情况下,这个由很多小的背景图像合成的大图被称为精灵图(雪碧图),如下图所示为京东网站中的一个精灵图。

精灵技术的使用

CSS 精灵其实是将网页中的一些背景图像整合到一张大图中(精灵图),然而,各个网页元素通常只需要精灵图中不同位置的某个小图,要想精确定位到精灵图中的某个小图,就需要使用CSS的background-image、background-repeat和background-position属性进行背景定位,其中最关键的是使用background-position属性精确地定位。

制作精灵图

CSS 精灵其实是将网页中的一些背景图像整合到一张大图中(精灵图),那我们要做的,就是把小图拼合成一张大图。

大部分情况下,精灵图都是网页美工做。

我们精灵图上放的都是小的装饰性质的背景图片。 插入图片不能往上放。

我们精灵图的宽度取决于最宽的那个背景。

我们可以横向摆放也可以纵向摆放,但是每个图片之间,间隔至少隔开偶数像素合适。

在我们精灵图的最低端,留一片空隙,方便我们以后添加其他精灵图。

2、滑动门

滑动门出现的背景

制作网页时,为了美观,常常需要为网页元素设置特殊形状的背景,比如微信导航栏,有凸起和凹下去的感觉,最大的问题是里面的字数不一样多,咋办?

为了使各种特殊形状的背景能够自适应元素中文本内容的多少,出现了CSS滑动门技术。它从新的角度构建页面,使各种特殊形状的背景能够自由拉伸滑动,以适应元素内部的文本内容,可用性更强。 最常见于各种导航栏的滑动门。

核心技术

核心技术就是利用CSS精灵(主要是背景位置)和盒子padding撑开宽度, 以便能适应不同字数的导航栏。

以下是完整的滑动门导航栏


<!DOCTYPE html>
<html>
<head>
	<title></title>
	<style type="text/css">
		body{
			background: url(images/wx.jpg) repeat-x;
		}
		li{
			list-style: none;
		}

		.nav a{
			height: 33px;
			line-height: 33px;
			text-decoration: none;
		    color: #fff;
		    display: inline-block;
		    background: url(images/to.png) no-repeat;
		    padding-left: 15px;

		   

		}
		.nav span{
			height: 33px;
			line-height: 33px;
			display: inline-block;
			background: url(images/to.png)no-repeat right;
		    padding-right: 15px;
		 
		}
		.nav a:hover,.nav a:hover span{
			background-image: url(images/ao.png);
		}
	</style>
</head>
<body>

	<ul class="nav">
		<li>
			<a href="#">
				<span>首页</span>
			</a>
			<a href="#">
				<span>客服管理</span>
			</a>
			<a href="#">
				<span>意见反馈</span>
			</a>
			<a href="#">
				<span>加入我们吧</span>
			</a>
		</li>
	</ul>

</body>
</html>

总结:

  1. a 设置 背景左侧,padding撑开合适宽度。

  2. span 设置背景右侧, padding撑开合适宽度 剩下由文字继续撑开宽度。

  3. 之所以a包含span就是因为 整个导航都是可以点击的。

3、字体图标

图片是有诸多优点的,但是缺点很明显,比如图片不但增加了总文件的大小,还增加了很多额外的"http请求",这都会大大降低网页的性能的。更重要的是图片不能很好的进行“缩放”,因为图片放大和缩小会失真。 我们后面会学习移动端响应式,很多情况下希望我们的图标是可以缩放的。 此时,一个非常重要的技术出现了, 这就是字体图标(iconfont).

字体图标优点

可以做出跟图片一样可以做的事情,改变透明度、旋转度,等..

但是本质其实是文字,可以很随意的改变颜色、产生阴影、透明效果等等...

本身体积更小,但携带的信息并没有削减。

几乎支持所有的浏览器 移动端设备必备良药...

字体图标使用流程

上传生成字体包

当UI设计人员给我们svg文件的时候,我们需要转换成我们页面能使用的字体文件, 而且需要生成的是兼容性的适合各个浏览器的。

推荐网站: http://icomoon.io

icomoon字库

IcoMoon成立于2011年,推出的第一个自定义图标字体生成器,它允许用户选择他们所需要的图标,使它们成一字型。 内容种类繁多,非常全面,唯一的遗憾是国外服务器,打开网速较慢。

推荐网站: http://www.iconfont.cn/

阿里icon font字库

http://www.iconfont.cn/

这个是阿里妈妈M2UX的一个icon font字体图标字库,包含了淘宝图标库和阿里妈妈图标库。可以使用AI制作图标上传生成。 一个字,免费,免费!!

fontello

http://fontello.com/

在线定制你自己的icon font字体图标字库,也可以直接从GitHub下载整个图标集,该项目也是开源的。

Font-Awesome

http://fortawesome.github.io/Font-Awesome/

这是我最喜欢的字库之一了,更新比较快。目前已经有369个图标了。

Glyphicon Halflings

http://glyphicons.com/

这个字体图标可以在Bootstrap下免费使用。自带了200多个图标。

Icons8

https://icons8.com/

提供PNG免费下载,像素大能到500PX

下载兼容字体包

字体引入到HTML

得到压缩包之后,最后一步,是最重要的一步了, 就是字体文件已经有了,我们需要引入到我们页面中。

  1. 首先把 以下4个文件放入到 fonts文件夹里面。 通俗的做法

第一步:在样式里面声明字体: 告诉别人我们自己定义的字体

@font-face {
  font-family: 'icomoon';
  src:  url('fonts/icomoon.eot?7kkyc2');
  src:  url('fonts/icomoon.eot?7kkyc2#iefix') format('embedded-opentype'),
    url('fonts/icomoon.ttf?7kkyc2') format('truetype'),
    url('fonts/icomoon.woff?7kkyc2') format('woff'),
    url('fonts/icomoon.svg?7kkyc2#icomoon') format('svg');
  font-weight: normal;
  font-style: normal;
}

第二步:给盒子使用字体

span {
		font-family: "icomoon";
	}

第三步:盒子里面添加结构

span::before {
		 content: "\e900";
	}
或者  
<span></span>

追加新图标到原来库里面

如果工作中,原来的字体图标不够用了,我们需要添加新的字体图标,但是原来的不能删除,继续使用,此时我们需要这样做

把压缩包里面的selection.json 从新上传,然后,选中自己想要新的图标,从新下载压缩包,替换原来文件即可。

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Spring Boot 是一个基于 Spring 框架的开发框架,它是构建独立、可部署的、生产级的 Spring 应用程序的最佳选择。在使用 Spring Boot 开发应用程序时,常用技术栈包括: 1. Spring Framework:Spring Boot 基于 Spring Framework,因此熟悉 Spring 框架是必备的。 2. Spring MVC:Spring MVC 是 Spring 框架中用于构建 Web 应用程序的模块,用于处理 HTTP 请求和响应。 3. Thymeleaf 或者 FreeMarker:这些是常用的模板引擎,用于在视图层渲染 HTML 页面。 4. Spring Data JPA:Spring Data JPA 是 Spring 提供的用于简化数据库访问的模块,它是 Java Persistence API(JPA)的实现。 5. Spring Security:如果你需要在应用程序中添加身份验证和授权功能,Spring Security 是一个非常好的选择。 6. Spring Boot Actuator:Actuator 是 Spring Boot 提供的监控和管理应用程序的模块,它可以帮助你暴露应用程序的健康状况、性能指标等信息。 7. 数据库:Spring Boot 支持多种数据库,包括 MySQL、PostgreSQL、Oracle、MongoDB 等。你可以根据项目需求选择合适的数据库。 8. 缓存:Spring Boot 集成了多种缓存框架,如 Ehcache、Redis 等,可以提高应用程序的性能。 9. 日志:Spring Boot 使用 Logback 或者 Log4j2 作为默认的日志框架,你可以根据需求进行配置。 10. 测试:Spring Boot 提供了方便的测试支持,包括单元测试、集成测试等。 以上是 Spring Boot 常用技术栈,根据项目需求和个人喜好可以进行选择和组合。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值