css img 适配尺寸_CSS容易使人蒙圈的几个经典问题

本文摘自这一年来自己在工作中经历的几个比较好的CSS问题(不一定复杂,但个人觉得都挺值得一说),同时也准备了2个JS问题

一、CSS篇

1.1 元素默认蓝色边框

input标签元素(如buttontextareatext)的一些事件(如clickfocus等),在很多浏览器下默认会有蓝色边框出现,如把一个普通buttonbackgroundborder都设置为none后,触发点击后样式如下:

e566aed86004724e6960158754c5a92e.png
rgba

这是由元素默认的轮廓线产生的,这是浏览器的一种防护机制,起到突出元素的作用,把它干掉就行了,方法如下:

// 方法1:
outline: none / medium;

// 方法2:
outline-width: 0

1.2 背景透明,文字不透明

我们通常是使用 opacity来做背景的透明化处理,该属性被所有浏览器支持,可以大胆使用,透明度从0.0(完全透明)到1.0(完全不透明),但该方法会使其所有子元素都透明,此时若只想让背景透明,其他不透明,则可以使用rgba处理背景:

background-color: rgba( red , green , blue , alpha )

其中这个alpha 即设置透明度,取值在0~1之间。该方法除IE9以下不可用外,其他浏览器均可用,看一下效果:

fd5237290a1ce6a90c2f7aaeb250ef7b.png
rgba

同理,我们也可以用这个方法把整个背景做透明了,即多写一个div作为modal层做透明处理,可以明显看到上面文字并未透明:

89ac9e2fbc540604ae0d803740100b67.png
整体背景透明

上述种效果代码如下:

// html
<section>
  <div class="item-pic">
    <header class="header1">
      <h4>你会微笑放手,说好不哭让我出新专辑h4>
    header>
  div>
  <div class="item-pic">
    <header class="header2">
      <h4>你会微笑放手,说好不哭让我出新专辑h4>
    header>
  div>
  <div class="item-pic">
    <div class="handle-opacity"> 
      <header>
        <h4>你会微笑放手,说好不哭让我出新专辑h4>
      header>
    div>
  div>
section>
<style lang="less">
.header1 {
  opacity: .6;
}
.header2 {
  background-color: rgba(0, 0, 0, 0.45);
}
.handle-opacity {
  position: absolute;
  width: 100%;
  height: 100%;
  background-color: rgba(255, 255, 255, 0.45);
  header {
    background-color: rgba(0, 0, 0, 0.45);
  }
}style>

1.3 div内置img元素,底部总有间距

用一个div包裹一个img,会出现img不能完全覆盖div空间,总会在底边留下一点空隙。

214ffb4208214dd9a03cb4f86577fab3.png
div底部间隙

这种现象产生的原因是img是行内元素,浏览器为下行字符(如:g、y、j、p、q)留下的一些空间,这些字符是会比其他字符多占据底部一些空间(具体以当前字体大小有关),这种规则会影响行内元素img标签(其默认垂直对齐方式是依照基线来的,即vertical-align: baseline),同样行内元素都会和外部元素留这么一丢丢安全距离。上图右侧就是加了文字的效果,这样就更说明一切了。

现在我们知道这种现象主要是由于下行字符串保护机制和img是行内元素这两个因素导致的,那解决方案就从这两处入手,整理如下:

  1. div设置font-size: 0line-height: 0,进而行高为0;

  2. img设置 vertical-align: top 或者 middle/,使其不再以默认基线为对齐方式;

  3. img设置 display:block,使其变成块级元素。

综上,个人认为方法3是最好用的,方法1不推荐使用。

1.4 元素自动填充上背景色

该现场多在表单输入等场景上会出现,初次看到确实很怪异,效果如图:

5d3b4bc612df8525d84fc3187d462704.png
默认颜色

即当浏览器(chrome)给输入框自动填充内容后,也会自动给输入框带上背景(黄或灰蓝),该问题是由于chrome会默认给自动填充的inputselecttextarea等加上:-webkit-autofill私有伪属性造成的,比较好的解决方案就是做样式覆盖,代码如下:

input:-webkit-autofill{
  box-shadow: 0 0 0px 1000px white inset !important;
}
select:-webkit-autofill{
  box-shadow: 0 0 0px 1000px white inset !important;
}
textarea:-webkit-autofill{
  box-shadow: 0 0 0px 1000px white inset !important;

比较渣的办法是设置禁止自动填充,但还是别那样做了…

1.5 transform 基数值导致字体模糊

transform作为CSS3最为自豪的属性,已经成为了当前前端开发中不可或缺的方法,但它有个渲染的问题,即当元素设置有transform,且其值为基数或小数,同事其整体高度也有基数时,其内部文字会变模糊,如图:

516b744527b8d155bb785c49a9d17e11.png
模糊

上图上模糊状态下的,下图是修正过的,具体原因经查可能是因为transform变换会在浏览器上单独创建一个绘画层并重新进行渲染,在此渲染过程中也处理了周围的文字,如果高度为奇数的文字可能会存在半个像素的计算量,浏览器对这半个像素会进行优化渲染,所以边缘会出现模糊的情况。解决方案即:

  1. 不要给transform属性值设置奇数和小数值;

  2. 调整整体元素高度不要为基数。

1.6 :last-child 和 :last-of-type

作为CSS常用伪类选择器,:last-child经常会被用到,但有时遇到极端情况,它会意外失效,让人摸不着头脑,例子如下:
3个img标签包裹在card中,当前需求是使最后一张图的边框呈粉色,代码如下:

// html
<div class="card">
  <img v-for="(item,i) in pics":key="i":src="item"
  />
div>
// css
<style lang="less">
.card {
  > img {
      width: 150px;
      margin-right: 10px;
      &:last-child {
        border: 5px solid pink;
      }
   }
}style>

同理用:last-of-type也能实现:

.card {
  > img {
      width: 150px;
      margin-right: 10px;
      &:last-of-type {
        border: 5px solid pink;
      }
   }
}

效果如下:

d393ee26ee0bf468cad6b9fcf76b670e.png
有效

现在要往img后加一个span,发现:last-child已失效:

// html
<div class="card">
  <img v-for="(item,i) in pics":key="i":src="item"
  />
  <span>next is ...span>
div>
// css
<style lang="less">
.card {
  > img {
      width: 150px;
      margin-right: 10px;
      &:last-child {
        border: 5px solid pink;
      }
   }
}style>
5b6ec8c57bb4c92ceab7969c281a6023.png
失效

而此时:last-of-type依然没问题:

9bcad33609810166c9d95d163aabd676.png
有效2

现在得出结论:

  1. :last-child选取一群兄弟元素中的最后一个元素,且最后的这个元素必须是所声明的指定元素(注意2个条件);

  2. :last-of-type选取一群兄弟元素中的最后一个指定类型的元素。

可知,:last-of-type更严谨一些,不容易产生意外bug,我更推荐使用它。同理适用于:nth-last-child(n):nth-last-of-type(n)

二、DOM篇

这部分我会叙述一些DOM操作遇到的一些容易被忽视的问题。

2.1 IOS日期显示问题

经常做H5移动端开发的朋友我想对这个问题肯定不陌生,那就是在部门IOS版本(IOS5及以下)中,对以“-”间隔的字符串时间格式的解析是不成功的,比如我们写了这么一个鸡肋时间格式适配器:

function DateFormat(date) {
  if(!date) return null;
  date = new Date(date);
  let Y = date.getFullYear();
  let M = (date.getMonth() >= 0 && date.getMonth() <= 8) ? `0${date.getMonth() + 1}` : `${date.getMonth() + 1}`;
  let D = (date.getDate() >= 0 && date.getDate() <= 9) ? `0${date.getDate()}`: `${date.getDate()}`;
  return `Y-M-D`
}

此时如果在IOS5及以下版本的iphone下,传入 "2019-12-31"就会呈现出 NaN-NaN-NaN,而其他IOS版本及安卓系统都是没问题的。

针对上述问题,要做兼容适配,即把以"-"间隔的事件字符串替换成以"/"即可,同样是这个适配器,添加一段代码:

function DateFormat(date) {
  if(!date) return null;
  if(typeof date === 'string' &&  date.indexOf('T')!=-1 && date.indexOf('+')!=-1) {
    date = date.replace(/-/g, '/').replace('T',' ').substring(0,date.indexOf('.'))
  }
  date = new Date(date);
  let Y = date.getFullYear();
  let M = (date.getMonth() >= 0 && date.getMonth() <= 8) ? `0${date.getMonth() + 1}` : `${date.getMonth() + 1}`;
  let D = (date.getDate() >= 0 && date.getDate() <= 9) ? `0${date.getDate()}`: `${date.getDate()}`;
  return `Y-M-D`
}

2.2 ENTER键使当前页刷新

这个真的很诡异的问题,当在一个表单中执行了ENTER键提交后,如果是打开新页面显示提交结果,则会发现当前表单页面也跟着刷新了,这种体验当然是很糟糕的。经查证,该问题的产生条件为:Form中只有一个input时,此时执行ENTER键会自动提交表单并刷新页面。解决方案也很粗暴,直接在input输入框附近写一个隐藏标签,这样就有2个input了,即避免了产生默认刷新的bug,实例如下:

<form>
  <input type="text" v-model.trim="searchText" placeholder="搜索您感兴趣的内容"
    @keyup.enter="goSearch" 
  />
  <input id="hidden" type="text" style="display:none" 
    @keyup.enter="goSearch"
  />
form>

❤️爱心三连击

如果你觉得这篇内容对你挺有启发,我想邀请你帮我三个小忙:

  1. 点个「在看」,让更多的人也能看到这篇内容(喜欢不点在看,都是耍流氓 -_-)

  2. 欢迎关注我的5000star文章合集 https://github.com/ljianshu/Blog,希望可以带给你点启发!

  3. 如果想进前端交流群一起探讨技术,请在后台回复「1

亲,点这涨工资 cb19ad9071a2669b3f8840242626c4a8.gif

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.tpcf.cn/news/328594.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

怎样增强MyEclipse的代码自动提示功能

转载自 怎样增强MyEclipse的代码自动提示功能 MyElipse的默认代码提示功能隐藏了许多细节&#xff0c;需要开发者手动设置&#xff0c;一起来设置吧&#xff0c;让你的myeclpse更强大 一般在Eclipse &#xff0c;MyEclipse代码里面&#xff0c;打个foreach&#xff0c;switch等…

第一篇:Dapper快速学习

我们都知道ORM全称叫做Object Relationship Mapper&#xff0c;也就是可以用object来map我们的db&#xff0c;而且市面上的orm框架有很多&#xff0c;其中有一个框架叫做dapper&#xff0c;而且被称为the king of ORM。 一&#xff1a;为什么选择Dapper 1. 性能优越&#xff1a…

配置spring、SpringMVC,mybatis进行整合

springframwork的官网 spring-projects/spring-mvc-showcase https://github.com/spring-projects/spring-mvc-showcase spring-projects/greenhouse https://github.com/spring-projects/greenhouse spring-projects/spring-boot spring-boot https://github.com/sprin…

对应node版本_安装Node.js教程

小编首先下载Node.js,首先打开浏览器&#xff0c;然后输入https://nodejs.org/en/&#xff0c;进入nodejs官网&#xff0c;然后按照下图中红色箭头指示步骤2&#xff0c;这个是nodejs8.12版本&#xff0c;下面Recommended For Most Users,这个就是推荐大家使用的版本&#xff0…

Asp.net Core 使用MyCat分布式数据库,实现读写分离

简介   MyCat2.0版本很快就发布了&#xff0c;关于MyCat的动态和一些问题&#xff0c;大家可以加一下MyCat的官方QQ群&#xff1a;106088787。我们今天主要介绍一下&#xff0c;在我们的Asp.net Core中如何使用Mycat&#xff0c;这源于一个大神&#xff08;Amamiya Yuuko&…

如何在MyEclipse中显示行数

转载自 如何在MyEclipse中显示行数如何在MyEclipse中显示行数呢&#xff1f;myeclipse在默认情况下不显示行数时&#xff0c;用户可以自己设置显示行数&#xff0c;行数可以帮助我们方便的查看代码。首先&#xff0c;打开windows菜单然后选择preference&#xff0c;进入首选项…

logback日志配置

直接复制讲一下好了 比较简单 logback 可以看到执行的sql了 mybatis执行的sql了 <?xml version"1.0" encoding"UTF-8"?> <configuration scan"true" scanPeriod"60 seconds" debug"false"><!-- 打印日…

旅游系统_数字洛江智慧旅游系统助力提升旅游安全水平

长期以来&#xff0c;景区客流监测工作都是个“老大难”问题。为进一步提升旅游安全监管水平&#xff0c;今年洛江区将该项工作列入民办实事项目&#xff0c;投入96万元&#xff0c;大力推进智慧旅游项目建设。日前&#xff0c;洛江区智慧旅游系统正式上线运行&#xff0c;该智…

如何在 ASP.NET MVC 中集成 AngularJS

介绍 当涉及到计算机软件的开发时&#xff0c;我想运用所有的最新技术。例如&#xff0c;前端使用最新的 JavaScript 技术&#xff0c;服务器端使用最新的基于 REST 的 Web API 服务。另外&#xff0c;还有最新的数据库技术、最新的设计模式和技术。 当选择最新的软件技术时&am…

ftp相关配置

ftp # 图片上传的会再讲的 #ftp的相关配置 #ftp.server.ip你的FTP服务器ip地址 ftp.server.ip127.0.0.1 ftp.usermmallftp ftp.passftppassword #ftp.server.http.prefixhttp://img.happymmall.com/.ftp.server.http.prefixftp://mmallftp:ftppassword127.0.0.1:21/img/ #ftp.…

MyEclipse web项目导入Eclipse,详细说明

转载自 MyEclipse web项目导入Eclipse&#xff0c;详细说明最近导入一个MyEclipse的项目&#xff0c;具体是&#xff1a;spring4.1的web项目&#xff0c;同时遇到了一些问题&#xff0c;总结一下。 1、进入项目目录&#xff0c;找到.project文件&#xff0c;打开。 增加一个&…

matlab盒子分形维数_分形:盒子维数

今天主要想说的是&#xff0c;分形中的差分盒子维数的原理&#xff0c;基于分形的基础概念就不在这里说啦.分形维数可以用于定量描述图像表面的空间复杂程度&#xff0c;能够定量的表现图像的纹理特征. 采用不同的维数进行纹理特征描述时&#xff0c;精度有所区别&#xff0c;我…

Eclipse中看不到jsp的页面效果

转载自 Eclipse中看不到jsp的页面效果eclipse打开jsp后&#xff0c;在文件下面部分应该有”design"视图的&#xff0c;你点击一下看看。还是没有的话&#xff0c;在JSP文件上点点右键,"open with"选"webpage editor"&#xff0c;然后下面应该有“des…

唤醒幻数据包禁用会怎么样_如何利用splashtop实现远程开机、远程唤醒电脑

Splashtop商业版和个人版提供了局域网唤醒计算机(WoL)功能&#xff0c;您可以按照下面的指引进行设置。首先&#xff0c;请确保完全满足以下三个条件&#xff0c;否则&#xff0c;远程唤醒无法工作。计算机 BIOS支持WoL并且该选项已启用。Windows或Mac计算机的操作系统中已正确…

第二篇:Dapper中的一些复杂操作和inner join应该注意的坑

上一篇博文中我们快速的介绍了dapper的一些基本CURD操作&#xff0c;也是我们manipulate db不可或缺的最小单元&#xff0c;这一篇我们介绍下相对复杂 一点的操作&#xff0c;源码分析暂时就不在这里介绍了。 一&#xff1a;table sql 为了方便&#xff0c;这里我们生成两个表…

eclipse安装、使用hibernate插件方法

转载自 eclipse安装、使用hibernate插件方法hibernate插件安装方法&#xff1a; http://download.jboss.org/jbosside/updates/stable 点击eclipse的help菜单里的“Install New Software”点击“Add”&#xff0c;输入下面的内容&#xff0c;一路“NEXT”即可 hibernate更新网…

编译内核_将驱动编译进内核(Kernel)的步骤记录

1、首先在/kernel/drivers下建立驱动文件&#xff1b;以建立hello文件为例2、在hello文件下创建.c/Makefile/Kconfig三个文件3、.c文件存放驱动程序&#xff1b;Makefile存放编译的方法&#xff1b;Kconfig存放编译的配置4、Makefile格式例如&#xff1a;“ obj-$(CONFIG_HELLO…

项目的提交

git status git add . git status git commit -am project init -a是提交 m是message放后面 git push git branch 完成了代码提交

Visual Studio “15”的第四个预览版发布

在Visual Studio “15”&#xff08;VS15&#xff09;首批披露的细节中&#xff0c;其中一个是围绕着VS15的安装过程。VS在年复一年地添加着各种功能&#xff0c;这导致占用了更多磁盘空间&#xff0c;并且安装需要更长时间。Microsoft为缩短开发人员的VS15软件安装时间&#x…