昨天把文章内目录(TOC)搓出来了,然而用的时候发现锚点跳转会被顶部导航栏盖住,简单查了一下,果然是可以用 CSS 解决的。...现象 这里借用一个提问的老哥画的一个很生动形象的文字示意图: WRONG (but the common behavior): CORRECT: +-------------------...h2{ padding-top: 顶栏高度; margin-top: -顶栏高度; } 示意图 负 margin 不会破坏文档流,用负 margin 减少自身高度,进而产生向上的偏移,且后面元素会继续紧贴着块...,然后使用负的 margin 让他向上偏移。...更推荐用 JavaScript,毕竟哪一天要改顶栏高度就得重新写 CSS 了。 不知道理解有没有错误,一直查资料,这篇文章查了得有 5 小时。最后还是不能确定到底是不是对的。
样式的继承和覆盖(重点) 当父标签设置了样式,子标签都会具有父标签的样式 示意图 ?...总结: 1.能继承的css属性:font系列,text系列,color,line-height 2.div可以继承父亲的宽度,高度不能继承 当子标签和父标签设置了同样属性的css,子标签会覆盖父标签的设置...总结: 继承:父元素设置了样式,子元素也具有了 覆盖:父元素和子元素有同样的样式,生效的是子元素,子元素覆盖了父元素的样式
用途 @supports CSS at-rule 关联了一组嵌套的CSS语句,这些语句被放置在一个CSS区块中,该区块以大括号分割, 还有一个由多个CSS声明检测组成的条件,它是一个键值组合, 由逻辑与...例子 基本方法 /*使用CSS的基本属性来进行检查:*/ @supports (display: flex) { div { display: flex; } } not声明——排除 @supports...反之,如果不同时支持这两个条件,那么浏览器将不会调用这部分样式。.../*使用CSS的基本属性来进行检查:*/ @supports (display: flex) { div { display: flex; } } 基本方法 /*使用CSS的基本属性来进行检查...:*/ @supports (display: flex) { div { display: flex; } } 基本方法 /*使用CSS的基本属性来进行检查:*/ @supports
更新的同时获取被更新的记录的id 一般我的写法是 select auto_id into v_id from history where state=1 and rownum=1; update...history set state=0 where auto_id=v_id 能不能把两条语句合成一条写呀 可以了 UPDATE BIZ_WORKFLOW SET SEND_MARK=1 WHERE...AUTO_ID=ID RETURN AUTO_ID INTO ID ;
css中 # 和 . 区别 . 用于id #用于class属性 html css中id和class的区别比较 1、语法区别: id对应css是用样式选择符“#”(井号)。...class对应css是用样式选择符“.”(英文半角输入句号)。 2、使用次数区别: id属性,只能被一个元素调用(以“#”选择符命名CSS样式在一个页面只能使用调用一次)。...在同一个页面,只可以被调用一次,在CSS里用“#”表示。...class类标记,可以用于被多个元素调用(以“.”选择符命名样式可以一个页面使用多次)是类标签,在同一个页面可以调用无数次(没限制的),在CSS里用“.”表示。...ID就像一个人的身份证,用于识别这个DIV的, Class就像人身上穿的衣服,用于定义这个DIV的样式。 一般一个网页不设二个或二个以上同ID的div,但Class可以多个DIV用同一个Class。
CSS动画是当前一种非常火爆的技术,我说的并不是一些简单的颜色变换或长短属性变换,我说的是3D变换技术;纯CSS实现的翻滚旋转立方体就是最典型的例子。...网上能找到很多关于CSS动画的代码,但对于一个程序员来说,真正理解其为什么会动起来的原理是非常重要的。下面让我来一步一步的带你理解网页中相互嵌套的3D动画是如何实现的!...3D变换,你唯一需要添加的CSS前缀可能只有-webkit-。...效果: 现在的效果看起来并不是很真实。更真实实现这种效果的CSS属性叫做perspective(透视),它会让东西看起来近处的大,远处的小。...看起来门的动画效果被门框的摆动抵消了。的确,事情就是这样,因为transform-style属性(用来告诉浏览器一个具有3D变换属性的子元素是否附随父元素的3D变换属性)的缺省值是flat。
介绍 首先我们先来看看 MDN 上对 content是如何描述的。 CSS 的 content属性用于在元素的 ::before和 ::after伪元素中插入内容。...通常你要实现一个动态的递增数,都是通过 JavaScript 实现,你可能都没有想过 CSS 也是可以实现递增数。 这个牛逼的东西就是「计数器」。...先来看看什么叫计数器: 本质上 CSS 计数器是由 CSS 维护的变量,这些变量可能根据 CSS 规则增加以跟踪使用次数。...counters()对嵌套的计数器非常有用,它可以在不同级别的嵌套计数器之间插入字符串。 比如:我们生成一个目录结构。 ?..."; } 参考: 《css世界》 Using CSS counters
这里我也只精简了部分代码,实际上要复杂的更多,但好在状态之间的依赖性还没有太强,没有出现嵌套多层『if else』判断,状态模式怎么改?...第三步,分别实现各个状态下关心的流转操作,我们举例其中两个状态子类的实现。...对比一下 实际订单状态这个例子并不是很完美契合状态模式,因为状态之间依赖性没那么强,很少可能会出现嵌套判断,但效果是很显然的。...试想一下,如果以后我的订单增加了一个状态叫『冻结状态』,那么我只需要创建一个新的状态类,并只关心我这个冻结状态相关的流转操作,重写一下就好了,根本不用跑到之前的逻辑里改啊改。...状态模式还是一个非常优秀的设计模式,推荐大家在项目里使用起来,除了初始编码的时候麻烦一点,后续的维护以及扩展真的近乎零成本。
-bash: /bin/tar: Argument list too long 这是由于 * 展开后参数长度超过系统参数 ARG_MAX 的限制 为了不报这种错误,我们考虑用find的参数扩展来试试...所以我猜想,第二批参数列表产生的压缩包把第一批参数列表产生的压缩包覆盖掉了,第三批又把第二批覆盖掉了。。。实际上只有最后一次传进来的参数被打进了压缩包中。.../$BID.tar # 用xargs追加进去所有的文件,这次不用怕被截断了~ find . -name "${BID}_*" | xargs tar uf ..../$BID.tar.gz "$BID"_* fi 其实 xargs 这些用法的区别有些类似于 http 协议中 " 幂等 " 的概念, tar cf 这种命令是不 " 幂等 " 的, rm 这类的命令则是..." 幂等 " 的,有兴趣的同事可以参考这个链接: http://zh.wikipedia.org/wiki/%E8%B6%85%E6%96%87%E6%9C%AC%E4%BC%A0%E8%BE%93%
来源:寒食君 作者:寒食君i 那个深夜,我登上了公司的服务器,在Redis 命令行里敲入 keys* 后,线上开始报警,服务瞬间被卡死,我只能举起双手,焦急地等待几千万key被慢慢扫描,束手无策万念俱灰的时候...ziplist或者intset,所以此处不会影响性能.游标在保存为hash的时候发挥作用,具体入口函数为dictScan,下文详细描述。...首先需要知道的前提是:Redis中进行rehash扩容时会存在两个哈希表,ht[0]与ht[1],rehash是渐进式的,即不会一次性完成。...注意之前所说的扩容方式:hash(key)&(size-1),slot0和slot4的内容是相同的,巧妙地避开了重复,当然,更不会遗漏。...字典扩大的情况没问题,那么缩小的情况呢?可以仿照着自己思考一下具体步骤。答案是可能会出现重复迭代,但是不会出现遗漏,也能够保证可用性。
在使用 yield 压平嵌套字典有多简单?这篇文章中,我们讲到,要把一个多层嵌套的字典压平,可以使用yield关键字来实现。 今天,我们倒过来,把一个已经被压平的字典还原成嵌套字典。...还原每一个嵌套字典 对于{'a_b_h':1},它实际上被还原以后应该是: {'a': {'b': {'h': 1}}} 现在,写一个函数unpack,这个函数的作用是传入两个参数['a', 'b',...目标字典的每一对 key, value被取出来,传入unpack函数构造每一个小的嵌套字典。 运行效果如下图所示: ? 合并字典 有了每一个嵌套字典以后,我们要做的就是把他们合并起来。...例如: { 'a_b_c': 1 'a': 2 } 这种字典不存在嵌套写法,因为{'a': 3}与{'a': {'b': {'c': 1}}}只能互相覆盖,不能合并。...当传入不能被转换的目标字典时,也会正常报错 ?
我可以向自己的用户解释“这是来自example.com的内容,如果它变冒犯了你,那是他们的错,可别来找我”,并寄希望于用户们能够相信我。 但是这种事肯定不会影响我数据库中密码字段之类的东西。...CSS不能修改原始存储,你不能用CSS写一个挖矿程序(也有可能,或许我还不知道),但恶意CSS仍然可以造成很大的破坏。 键盘记录器 咱们从最开始的那个问题开始 ?...默认情况下,浏览器不会将用户输入的值存储在 value属性中,因此攻击往往在同步这些值的内容时发生,例如React。...攻击者还可以在页面上放一个非密码文本输入框(可能是搜索字段)并将其覆盖在密码输入框之上,呵呵,现在他们又回来了。 读取属性 你担心的可不仅仅是密码。 一些私有内容可能会保存在属性中: ?...所有这些都可以被CSS选择器设为目标,并且可以把结果发到某个服务器上。 监控互动 ? 可以将hover和active等动作发送回服务器。 适当的使用CSS,你可以很好地了解用户想要干什么。
css中id选择器的注意点 注意: 1、每个HTML标签都有一个属性叫做id, 也就是说每个标签都可以设置id 2、在同一个界面中id的名称是不可以重复的 3、在编写id选择器时一定要在id名称前面加上...# id的名称是有一定的规范的 id的名称只能由字母/数字/下划线,a-z 0-9 _ id名称不能以数字开头 id名称不能是HTML标签的名称,不能是a h1 img input ......在企业开发中一般情况下如果仅仅是为了设置样式, 我们不会使用id ,因为id是留给js使用的 作用:根据指定的id名称找到对应的标签, 然后设置属性 格式: #id名称{ 属性:值; } 以上就是...css中id选择器的注意点,希望对大家有所帮助。
CSS嵌套提供了将一个样式规则嵌套在另一个样式中的能力,子规则的选择器相对于父规则的选择器。类似的行为以前需要CSS预处理器。 在Web开发中,CSS是一种关键的技术,用于样式化HTML元素。...CSS原生嵌套语法是一种CSS预处理器中常见的语法,它允许我们在样式表中使用嵌套的规则和选择器来组织样式代码。通过嵌套语法,我们可以更清晰地表示元素之间的层级关系,提高代码的可读性和维护性。...继承与覆盖 CSS原生嵌套语法具有继承和覆盖的特性。当子元素嵌套在父元素内部时,它会继承父元素的样式属性,从而减少代码的重复性。...同时,如果需要覆盖父元素的样式,只需在子元素中重新定义该属性即可。 嵌套选择器的应用 嵌套选择器是CSS原生嵌套语法的一大亮点,它能够帮助我们编写更具可读性和维护性的选择器。...通过选择器嵌套、属性嵌套和伪元素嵌套等基本语法规则,我们可以更好地表达元素之间的层级关系和样式属性。继承与覆盖的特性使得代码更具灵活性和可维护性。
效果一预览,瞬间眉头皱了起来:热力图几乎被轮廓“盖没了”!经过一番摸索与咨询官方技术支持,问题终于迎刃而解。这篇文章就来分享这次踩坑经历,告诉你该怎么正确“安排”这两张图层的关系。...device-width, initial-scale=1.0, minimum-scale=1.0, maximum-scale=1.0, user-scalable=no" /> css...="container"> id="setOptions"> id="show">显示/隐藏热力图 id="data...}); // 获取热力数据 var data = getHeatData(); heat.setData(data); // 以热力图中心点为中心,生成覆盖热力图的轮廓...总结通过本文的介绍,相信你已经掌握了腾讯地图中热力图被遮挡的解决技巧 —— 只需要添加 zIndex 属性,就能轻松让热力图“浮上来”。这个问题本身不复杂,但由于文档提示不足,很容易被忽略。
最近在做一个RN的app端调试工具,在把它嵌入原生app中的时候遇到了一个问题,RN组件里面接受不到原生传过来的initialProps?!...,作为AppRegistry.registerComponent的入口文件,这个时候react-navigation在接收到initialProps之后并不会向下传递,而是只向下传递自身的navigation...官方文档是这么介绍的啊, 这里的initialProperties注入了一些演示用的数据。在 React Native 的根组件中,我们可以使用this.props来获取到这些数据。...目前的开发工作,除非是原创性的工作,一般情况下你遇到的问题都是别人遇到过的,只要去找,可能会很长时间,但终归还是可以解决的,github的issue是个找答案的好地方,耐心寻找。...烦躁并不能解决问题,只会扰乱你的思路,所以不要被情绪左右你的理智。 ~加油 你是最胖的~
第一次参与工作组讨论的是关于 [css-grid-2] Allow minmax where max wins over min,很开心自己的提议被标准采纳了,预计会在 CSS Grid Layout...她觉得是时候该重新考虑 CSS 原生嵌套的问题了。 2017年7月13日,集设计和开发才能于一身的 UI/UX 自由工作者 Sara Soueidan 说嵌套是她最想要的 CSS 功能。...2017年8月15日,node-inspect 的作者 Jan Olaf Krems 说 cssnext 把嵌套定义成了“明天的 CSS”,但他还是想看到原生的 CSS 嵌套,毕竟 JS 的生态系统已经证明避免...CSS工作组的讨论流程 1.要支持原生嵌套 嵌套的样式规则是一个普遍的诉求 现存的 CSS 预处理器都支持写嵌套,且它是最受欢迎的功能之一 有了原生嵌套,就可以不用预处理器了 2.决定仅增加嵌套语法糖...前瞻符,诸如: # ID 选择器 . 类选择器 [] 属性选择器 * 通用选择器 : 伪类 :: 伪元素 ? 图2.
0 前言 全是干货的技术殿堂 jacoco是一个开源的覆盖率工具,通过插桩方式来记录代码执行轨迹. ant是构建工具,内置任务和可选任务组成的.Ant运行时需要一个XML文件(构建文件)。...,并将执行的数据写入此TCP连接,从而实现不停止项目运行实时生成代码覆盖率报告 port:开启的端口号 address: 开启的ip地址,本地写127.0.0.1 jar:运行服务的jar包地址...5 打开"index.html"报告,展示类的覆盖率文件 ? 什么方法级别覆盖率你都还不满足,想看到底哪行代码覆盖到了?...,即 com 目录的上一级目录,就能完美展示源码的覆盖率情况了 ? ?...绿色的为行覆盖充分 红色的为未覆盖的行 红色菱形的为分支全部未覆盖 黄色菱形的为分支部分覆盖 绿色菱形为分支完全覆盖 6 测试报告过滤 方案分两种 在jacoco配置中过滤 在class文件夹中删除掉无用的
jacoco是一个开源的覆盖率工具,通过插桩方式来记录代码执行轨迹. ant是构建工具,内置任务和可选任务组成的.Ant运行时需要一个XML文件(构建文件)。...,并将执行的数据写入此TCP连接,从而实现不停止项目运行实时生成代码覆盖率报告 port:开启的端口号 address: 开启的ip地址,本地写127.0.0.1 jar:运行服务的jar包地址 java...,port=8888,address=127.0.0.1 4 生成报告 ant dump 生成"jacoco.exec" ant report 5 打开"index.html"报告,展示类的覆盖率文件...什么方法级别覆盖率你都还不满足,想看到底哪行代码覆盖到了?...,即 com 目录的上一级目录,就能完美展示源码的覆盖率情况了 绿色的为行覆盖充分 红色的为未覆盖的行 红色菱形的为分支全部未覆盖 黄色菱形的为分支部分覆盖 绿色菱形为分支完全覆盖 总结 基操到此结束
element抽屉el-drawer被其他内容覆盖的解决方法 遮罩和下层的内容覆盖在了抽屉之上....解决办法是修改append-to-body和modal-append-to-body属性,把抽屉插入至 body 元素上,把遮罩插入至抽屉的父元素上,具体代码: <el-drawer...:append-to-body="true" :modal-append-to-body="false" > element官方的说明: 参数 说明 类型 可选值...嵌套的 Drawer 必须指定该属性并赋值为 true boolean - false modal-append-to-body 遮罩层是否插入至 body 元素上,若为 false,则遮罩层会插入至...Drawer 的父元素上 boolean - true