-
MediaQuery是CSS3根据设备特性应用不同样式的机制,核心语法为@mediascreenand(条件){样式规则},常用min-width和max-width设置断点;推荐移动优先策略,先定义小屏样式,再逐步增强大屏体验,结合HTML的link标签可控制外部CSS文件的条件加载,提升性能与维护性。
-
IE8不支持oninput,必须用onpropertychange替代,但需过滤propertyName、防递归触发、处理disabled失效及JS赋值场景,contenteditable和textarea需轮询兜底。
-
JavaScript生成器函数是可暂停执行的函数,返回迭代器对象;调用后需用next()推进执行,yield暂停并输出值,return终止并设done:true。
-
用scrollHeight实现textarea高度自适应最稳定:每次input前先设style.height='auto',再读取并设置scrollHeight;需处理IE11换行符偏差和iOSSafari延迟问题。
-
纯HTML+JavaScript实现购物车需用HTML结构、CSS样式、JS交互,核心是添加商品、更新数量、计算总价,配合localStorage持久化与事件委托绑定。
-
video的poster属性必须为可访问的http/https网络URL,不支持本地路径;需配合preload="metadata"和有效src才能显示;播放结束后需手动监听ended事件恢复封面。
-
可通过五种方法复制HTML或文本:一、开发者工具复制outerHTML/innerHTML;二、控制台解除选择限制;三、使用浏览器扩展;四、控制台执行querySelector+clipboard.writeText;五、保存网页后编辑提取。
-
用absolute定位圆点时父容器必须设position:relative,否则圆点会相对于body定位;border-radius:50%要求宽高相等才能成圆;微调位置优先用top/right等四方向偏移而非transform;多圆点推荐用box-shadow实现光晕或双环效果,便于主题色统一维护。
-
<p>text-align-last在Safari中完全不支持:所有版本均未实现,加-webkit-前缀也无效,浏览器静默忽略该属性;可用::after伪元素配合text-align:justify模拟末行对齐,但存在单行误换行、固定高度裁切、连字符干扰等限制。</p>
-
用max-width配合width:100%是控制容器响应式宽度最稳妥的方式,比单纯用width:100%或width:100vw更可靠,尤其在嵌套、缩放、滚动条场景下不容易溢出或错位。
-
用width和height相等+border-radius:50%能画出圆,但“完美对齐”需同步处理vertical-align、display、line-height及字体度量;根本原因是inline元素按baseline对齐,导致圆点视觉下沉。
-
最简实现左右分栏拖拽需用resize:horizontal+overflow:hidden+display:flex,左栏设min-width、flex-shrink:0,右栏flex:1;需ResizeObserver监听左栏尺寸变化,用contentRect.width获取准确宽度。
-
BFC是解决浮动侧边栏高度不一致导致底色断层的标准解法,推荐overflow:hidden触发;底色伪装和边框拉伸属临时补救,本质未解决问题;现代布局应优先选用Flex或Grid。
-
Grid子项默认不继承父容器高度,需通过grid-template-rows(如1fr)定义行轨道高度,align-self:stretch仅在子项无显式高度且轨道尺寸确定时生效。
-
纯CSS无法实现数字动态滚动,必须用JavaScript配合requestAnimationFrame控制数值演进,结合IntersectionObserver触发及正则提取纯数字,确保平滑、精准、低开销。