如何在带有 HTML 输出的 tufte-style Bookdown 中的每一章重置旁注编号?

问题描述

我正在使用 tuftemsmbstyle 包将 tufte-LaTeX 书籍转换为 tufte-Bookdown。我有一大堆旁注,我希望每章都重新开始编号,这样在本书结束时我不会达到 400。

我在 Bookdown GitHub 中找到了 this CSS code,用于使用常规 Bookdown 执行此操作,该 Bookdown 使用脚注/尾注。但是,我尝试修改代码以使用旁注的尝试失败了。这是我当前的 CSS 添加,它只需要该代码并放入 sidenotesidenote-number(Inspect Element 建议是正确的标签),其中 footnote 最初是:

/* generate new footnote calls */
.sidenote-number::after {
  content: counter(fn-call);
  position: relative;
  top: -.5em;
  font-size: 85%;
  line-height: 0;
  vertical-align: baseline;
}

/* use a counter for footnotes numbering */
.sidenote ol {
  list-style: none;
  counter-reset: fn-number;
}

.sidenote li {
  counter-increment: fn-number;
}

.sidenote li p:first-child::before {
    content: counter(fn-number) '. ';
    width: 1.5em;
    float: left;
}

这不会按预期工作,而是添加一个新的计数器,该计数器为每个旁注标记编号,并为每个标记重置一个计数器,因此文本标记获得 1 和旁注标记得 2。

Sidenote marker with its own sidenote markers

我的 CSS 技能并不出色,我不确定下一步是正确的。如何重置实际标记

您可以看到一个使用 tufte/msmbstyle here 构建的页面示例;只需向下滚动一点即可找到旁注 4。

解决方法

我最终花钱请人来解决这个问题。他们编写了一些 JavaScript 来修复它。下面的代码可以保存为HTML文件,并用

添加到书中
includes:
  in_header: thishtmlfile.html

在 YAML 中。这是 HTML/JS/Jquery 的代码:

<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.11.2/jquery.min.js"></script>
<script>
  $(document).ready(function () {
    var element_label= $("label[for *= 'tufte-sn-']");
    var count = $(element_label).length;
    $(element_label).each(function( index ) {
      //console.log( ++index + ": " + $( this ).text() );
      $(this).attr('for','tufte-sn-'+ ++index);
      $(this).text(index);
    });
  });
  $(document).ready(function () {
    var element_input= $("input[id *= 'tufte-sn-']");
    var count = $(element_input).length;
    $(element_input).each(function( index ) {
      //console.log( ++index + ": " + $( this ).text() );
      $(this).attr('id','tufte-sn-'+ ++index);
    }); 
  });
  $(document).ready(function () {
    var element_span= $("span[class *= 'sidenote-number']");
    var count = $(element_span).length;
    $(element_span).each(function( index ) {
      //console.log( ++index + ": " + $( this ).text() );
      $(this).text(++index);
    }); 
  });
</script>
,

我的建议是您先在 Latex 文件中修复它,然后 然后 import/Convert 它。

在文档的开头/序言添加这些行,它将在每一章启动/重置旁注计数器

% the answer --restarting the footnote at 0
\let\oldchapter\chapter
\def\chapter{%
  \setcounter{footnote}{0}%
  \oldchapter
}

% now your doc
\begin{document}


% would have helped if you pasted some chapters or your book...
% some chapters...
\chapter{First}
\yourtext

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...