zoukankan      html  css  js  c++  java
  • 页面建构

    最近一段时间因为工作强度比较大,而我也正是那种往往在高强度和压力状态下才会冒出ideal的屌丝,因此最近在页面建构方面的收获也颇丰,现在作为笔记记下来。

    (1)关于构造雪碧图的一点点经验

           以前最害怕的就是拼雪碧图了,特别是有hover状态的,因为一个像素的差别都会导致,当鼠标hover上去的时候图片会发生跳动。恰好这次页面上有巨多的hover状态,看见就郁闷了。也许真的是时间太紧了,如果按照以前的那种拼图的方法,在一天之内根本是完不成的任务的,穷则思变,自己想了一套拼雪碧图的方法,使用了一下还比较靠谱,现在就将它记下来。

           a)在雪碧图之前,我们需要一个适合大小的画布(canvas),在Ps下面的命令是Ctrl+N,画布的大小最好是10的整数倍,至于原因后面会用上

           b)创建好画布后,下面的就是规划画布,因为在使用background-position时颇有差之毫厘失之千里的感觉,所以画布一定要好好规划,在规划画布的时候还要联系页面元素的大小,如果页面最小的

              图标都是20px * 20px的,那么此时你的画布每个单位的大小就不应该小于20px * 20px. 在这一步中需要用到PS中的一个Grid的东西,快捷键是Ctrl + '(Enter 键左边的那个键),当弹出grid的时候

              可能不符合你标准这时需要更改每个grid的大小,单击“编辑——首选项——参考线、网格和切片”,在右边找到“网格”,可以设置网格线间隔、颜色、样式等。

             c)当规划好画布后,下面的事就比较简单了,找到参考线,好好的进行排图,将相关的图尽量放在一起,并且是按照单元格来放。

                

            这样第一个图和第二个图当hover状态就不会出现偏差了。

     总结:使用上述方法的好处就是在用background-position定位的时候比较容易,并且都是整数值。还有一个需要注意都是在拼完后一定要保存好psd,因为这些图很有可能在后面的工程中会发生变化,为了

    不造成重拼和图片的浪费,直接调整原图是比较靠谱的。

    (2)关于text-align的用法的探讨

                  下面是一个demo的地址http://jsfiddle.net/xiaoxiong_1990/9VMTC/ 在这个demo中可以看见下面的文字并没有按照我们预想的那样进行居中,但是有一个怪异的现象的是,当你F12,通过控制台工具选中这个a元素的时候,这个时候文字就会发生奇异的现象,它竟然居中了,这一点是我始终没有想通的一个问题。但是普通用户来看文字没有居中,这就是一个问题。从出现的现象来看应该是text-align属性出了问题。

                  在CSS2的规范中看见了有两处讲到了关于text-align这个属性:

    通过三者的综合以及根据http://www.w3.org/TR/CSS2/visudet.html#abs-non-replaced-width对a里面,方位值的计算,我们不难得到为何当span的display:absolute时文字没有居中。

                  a)因为a的text-align为center,所以a里面的inline-block是从中部开始定位的,根据http://www.w3.org/TR/CSS2/visudet.html#abs-non-replaced-width中的如果'left','width','right'都为auto,的话,根据direction首先确定span的left值,这里的left值真好是50px,然后是根据规则span的宽度值是根据shrink算法得到。这样也就解释了为什么span是右边界对齐a的中间部分。

                  b)修正:其实关于这个问题有很多的实现方式,最简单的就是将span的position改为releative,这样关于span的left,width等值的计算将会按照http://www.w3.org/TR/CSS2/visudet.html#inline-width,这个来计算,这样span的left,right计算后的值就为0.然后span是a里面的inlline-level 的box,这时span的开始位置就是a的中间位置。

     
    分类: web前端
  • 相关阅读:
    让 vscode 作为 SpringBoot,Java,Maven,甚至于 JavaScript,C,C++,Python,Php等多语言的开发工具吧!
    MySQL 连接错误集锦
    前端开发工具库:包含事件委托,动画处理,以及大部分常用的前端工具
    初探 Node.js 框架:eggjs (环境搭配篇)
    如何快速搭建一个 Node.JS 项目并进入开发?
    关于 JavaSrcipt 前端开发的建议:模块化开发
    Spring-Session 会话共享 -> 基于 Redis 集群,内附各大错误合集,包括配置,类寻找不到、连接错误等
    Java Email 邮件发送
    CSS 显示或隐藏子元素
    Ubuntu美化及配置,常见问题解决方案(仿 Mac 风格)
  • 原文地址:https://www.cnblogs.com/Leo_wl/p/2646820.html
Copyright © 2011-2022 走看看