记录一下平时遇到的css问题

本文详细解析了CSS中常见的布局问题,包括img与div的间隔、多行文本溢出省略、页面滚动条引起的跳动及font-size:0px的作用。提供了实用的代码示例,如vertical-align属性调整图片对齐、利用CSS属性解决多行文本溢出显示省略号、通过calc和vw或:root解决页面跳动问题,以及如何消除inline-block元素间的莫名间距。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

img与div下边有间隔

图片文字等inline元素默认与父级元素的baseline对齐,而baseline又和父级底边有必定间隔(这个间隔和 font-size,font-family 相关),所以设置 vertical-align:top/bottom/text-top/text-bottom 都能够防止这种状况呈现。
1.img标签添加vertical-align:bottom,vertical-align:middle,vertical-align:top;

 img{vertica## 标题l-align:bottom;}

2.定义容器里的字体大小为0:

 div {font-size:0}

css多行文本溢出省略

eg:第二行超出部分文字省略样式如下

div{
  overflow: hidden;
  text-overflow: ellipsis;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  }

浏览器出现滚动条页面跳动问题

当页面内容过长浏览器会出现滚动条导致页面发生跳动,影响用户体验,现代浏览器下可以使用css解决这个问题代替js计算。
1.利用calc和vw

.wrap-outer { margin-left: calc(100vw - 100%); }
@media screen and (min-width: 1150px) {
  .wrap-outer {margin-left: calc(100vw - 100%); }
}

2.利用:root

html {overflow-y: scroll; }
:root {overflow-y: auto;overflow-x: hidden; }
:root body { position: absolute; }
body {width: 100vw;overflow: hidden; }

font-size:0px作用

父元素设置font-size:0,可避免子元素display:inline-block时之间莫名其妙的间距。

.box{
            width: 200px;
            height: 30px;
            line-height: 30px;
            font-size: 0;
 }
.box>div{
            display: inline-block;
            width: 60px;
            border: 1px solid #000000;
            font-size: 16px;
            /*float: left;不建议使用*/
}
由于该文档中的问题较多且较为复杂,我将针对每个问题提供简洁而专业的答案: ### 数据库相关 1. **项目中有没有使用过MySQL优化?** - 是的,在项目中我们通过索引优化、查询优化、慢查询分析等手段提高了数据库性能。 2. **项目中的日志如何处理?** - 使用Logback或Log4j进行日志记录,并通过ELK Stack(Elasticsearch, Logstash, Kibana)进行日志管理和分析。 3. **项目中设计过哪些表,对表的设计如何考虑?** - 设计了用户表、订单表、商品表等。表设计时考虑了规范化、索引、字段类型选择等因素,以提高性能和减少冗余。 4. **MySQL事务的隔离级别以及不同隔离级别的问题?** - 隔离级别包括:Read Uncommitted、Read Committed、Repeatable Read、Serializable。不同的隔离级别可能导致脏读、不可重复读、幻读等问题。 5. **MySQL索引失效的场景有哪些?** - 场景包括:使用函数或表达式、隐式类型转换、使用前缀索引但不匹配、使用 OR 语句连接多个条件等。 6. **MySQL事务的四大特性如何实现?** - ACID特性:Atomicity(原子性)、Consistency(一致性)、Isolation(隔离性)、Durability(持久性)。通过事务管理器、日志、锁定机制等实现。 7. **谈谈你对MvCC的理解?** - 多版本并发控制(MVCC)允许多个事务同时访问同一数据的不同版本,从而提高并发性能。主要通过保存历史版本来实现。 ### Java 相关 8. **如何和前端进行数据交互?** - 通常使用RESTful API进行数据交互,通过JSON格式传输数据。 9. **项目中遇到过哪些问题?** - 遇到了性能瓶颈、并发问题、数据一致性问题等,通过优化代码、增加缓存、调整数据库配置等方式解决。 10. **项目中有没有遇到过内存泄漏和CPU被打满?** - 是的,通过Profiler工具定位并解决了内存泄漏问题;通过监控和调优解决了CPU被打满的问题。 11. **项目中有没有用到异步多线程以及遇到了什么问题?** - 使用了Executor框架进行异步多线程处理,遇到的问题包括线程安全、任务提交失败等,通过合理配置线程池和异常处理解决。 12. **jvm调优了解过哪些?** - JVM运行时数据区包括:方法区、堆、虚拟机栈、本地方法栈、程序计数器。每个区域有不同的用途,如存储对象实例、方法信息等。 14. **垃圾回收算法有哪些以及谈谈CMS垃圾回收器的了解?** - 常见的垃圾回收算法包括:标记-清除、复制、标记-整理、分代收集。CMS(Concurrent Mark Sweep)是一种低延迟的垃圾回收器,适合处理大量数据的应用。 15. **创建线程池的方式有哪些execute和submit的区别?** - 创建线程池的方式包括`newFixedThreadPool`、`newCachedThreadPool`、`newSingleThreadExecutor`等。`execute`用于执行Runnable任务,不返回结果;`submit`可以执行Callable任务,返回Future对象。 16. **如何实现两个线程通信,编写一段代码?** ```java import java.util.concurrent.BlockingQueue; import java.util.concurrent.LinkedBlockingQueue; public class ThreadCommunication { private static final BlockingQueue<String> queue = new LinkedBlockingQueue<>(1); public static void main(String[] args) throws InterruptedException { Thread producer = new Thread(() -> { try { for (int i = 0; i < 10; i++) { queue.put("Message " + i); System.out.println("Produced: Message " + i); } } catch (InterruptedException e) { e.printStackTrace(); } }); Thread consumer = new Thread(() -> { try { while (true) { String message = queue.take(); System.out.println("Consumed: " + message); } } catch (InterruptedException e) { e.printStackTrace(); } }); producer.start(); consumer.start(); producer.join(); consumer.interrupt(); } } ``` 17. **volatile的作用是什么,如何理解JMM内存模型?** - `volatile`关键字确保变量的可见性和禁止指令重排序。Java内存模型(JMM)定义了线程和主内存之间的交互规则,确保多线程环境下的内存可见性和有序性。 ### Spring 相关 18. **项目中用到过SpringCloud的哪些组件?** - 使用了Eureka、Ribbon、Feign、Hystrix、Zuul等组件。 19. **谈谈你对SpringBoot的自动配置原理?** - SpringBoot通过`@EnableAutoConfiguration`注解启用自动配置,扫描类路径下的`spring.factories`文件,加载对应的自动配置类。 20. **SpringBoot和SpringCloud的配置文件加载顺序以及优先级?** - 加载顺序为:`bootstrap.yml` > `application.yml` > `application-{profile}.yml`。优先级从高到低依次为:命令行参数、系统属性、环境变量、配置文件。 21. **@Autowired注解和@Resource注解的区别?** - `@Autowired`基于类型进行注入,默认按类型查找,支持字段、构造器、方法注入。`@Resource`基于名称进行注入,默认按名称查找,支持字段、方法注入。 22. **BeanFactory和Factory的区别?** - `BeanFactory`是Spring的核心容器,负责管理Bean的生命周期和依赖关系。`Factory`是一个泛指的概念,用于创建对象的工厂模式。 23. **如何理解Spring的AOP?** - AOP(面向切面编程)允许开发者将横切关注点(如日志、事务管理)模块化,通过织入技术将其应用到目标对象上,提高代码复用性和维护性。 24. **如何理解Spring的生命周期?** - Spring Bean的生命周期包括:实例化、属性赋值、初始化、使用、销毁。通过各种接口和回调方法可以自定义生命周期行为。 25. **Spring事务失效的场景有哪些?** - 事务失效的常见场景包括:事务传播行为不当、异常被捕获、使用了非受管事务的方法等。 26. **Spring事务的传播行为有几种?** - 传播行为包括:REQUIRED、REQUIRES_NEW、SUPPORTS、NOT_SUPPORTED、MANDATORY、NEVER、NESTED。 27. **SpringMvc的流程介绍一下?** - 请求到达DispatcherServlet,解析请求映射到Controller,调用HandlerAdapter执行Handler,返回ModelAndView,视图解析器解析视图,渲染视图,响应客户端。 28. **@RequestBody和@ResponseBody的区别?** - `@RequestBody`用于将HTTP请求体中的数据绑定到控制器方法的参数上。`@ResponseBody`用于将控制器方法的返回值直接写入HTTP响应体。 ### 其他 29. **MyBatis如何实现分页的?** - MyBatis通过`RowBounds`对象或插件方式实现分页,插件方式更灵活,支持多种数据库。 30. **线程池的工作原理?** - 线程池预先创建一组线程,任务提交到工作队列,由空闲线程执行。线程池管理线程的创建、分配和销毁,提高资源利用率和响应速度。 31. **订单的数据量有多少、ES中的数据量有多少,平台有多少张专辑和声音?** - 具体数据量需要查看实际系统统计,一般可以通过数据库查询或ES索引统计获取。 32. **平时压测工具用的是什么,会关注哪些压测指标?** - 常用的压测工具有JMeter、LoadRunner、Gatling等。关注的指标包括:响应时间、吞吐量、错误率、TPS等。 33. **幻读和不可重复读的区别?** - 幻读是指在一个事务内多次查询同一条记录,发现新增了其他事务插入的记录。不可重复读是指在一个事务内多次查询同一条记录,发现记录被其他事务修改。 34. **产生死锁的条件?** - 死锁产生的四个必要条件:互斥条件、请求与保持条件、不剥夺条件、循环等待条件。 35. **项目中核心业务接口的并发量多少?** - 具体并发量需要通过压测工具测试确定,一般情况下可以根据系统的QPS(每秒查询率)来估算。 36. **网络的4层5层七层模型简述一下?** - OSI七层模型:物理层、数据链路层、网络层、传输层、会话层、表示层、应用层。TCP/IP四层模型:网络接口层、互联网层、传输层、应用层。五层模型介于两者之间。 37. **项目在使用Redis时遇到了哪些问题?** - 遇到的问题包括:内存不足、数据丢失、网络延迟等,通过合理配置Redis、使用持久化、优化网络等方式解决。 38. **前端了解过哪些?** - 了解HTML、CSS、JavaScript、React、Vue等前端技术和框架。 39. **RabbitMQ如何保证百分百投递?** - 通过确认机制(publisher confirms)、持久化消息、镜像队列等措施保证消息的可靠投递。 40. **接口幂等性的保证有哪些?** - 通过唯一标识符、状态检查、版本号等方式保证接口的幂等性。 41. **编写一个生产者消费者模型。【两个线程+一个阻塞队列】** ```java import java.util.concurrent.BlockingQueue; import java.util.concurrent.LinkedBlockingQueue; public class ProducerConsumerExample { private static final BlockingQueue<String> queue = new LinkedBlockingQueue<>(10); public static void main(String[] args) { Thread producer = new Thread(new Runnable() { @Override public void run() { try { for (int i = 0; i < 10; i++) { queue.put("Item " + i); System.out.println("Produced: Item " + i); } } catch (InterruptedException e) { e.printStackTrace(); } } }); Thread consumer = new Thread(new Runnable() { @Override public void run() { try { while (true) { String item = queue.take(); System.out.println("Consumed: " + item); } } catch (InterruptedException e) { e.printStackTrace(); } } }); producer.start(); consumer.start(); } } ``` 希望这些答案能帮助你更好地准备面试。如果有任何具体问题需要进一步解释,请随时告诉我!
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值