JavaScript笔记 #05# 用Regex辅助生成文章目录
PS. 用来生成个人笔记的目录
1、输入:html文本
<h2>Notes</h2>
<p>1、小标题1。正文正文正文</p>
<div class="cnblogs_code">
<pre><span style="color: #000000;">ddjlasjdlas
</span><span style="color: #0000ff;">as</span><span style="color: #000000;">
dasdasjda</span></pre>
</div>
<p>2、小标题2</p>
<p>正文正文正文正文正文</p>
<p>3、小标题3</p>
<p>正文正文正文</p>
<p>4、小标题4</p>
<p>正文正文正文</p>
<p> </p>
<h2>Excercises</h2>
<p>① xxxxxx1</p>
<p>正文正文正文</p>
<p>② xxx2</p>
<p>正文正文</p>
<p>③ xx3</p>
<p>正文正文正文</p>
2、输出:含目录的html文本
<div id="diy_right_menu">
<h2>索引</h2>
<ul>
<li>
<p>Notes</p>
<ol>
<li><a href="#a1">标题1</a></li>
<li><a href="#a2">标题2</a></li>
<li><a href="#a4">标题3</a></li>
<li><a href="#a5">标题4</a></li>
</ol></li>
<li>
<p>Excercise</p>
<ol>
<li><a href="#b1">练习1</a></li>
<li><a href="#b2">练习2</a></li>
<li><a href="#b3">练习3</a></li>
</ol></li>
</ul>
</div>
<h2>Notes</h2>
<p><a name="a1"></a>1、小标题1。正文正文正文</p>
<div class="cnblogs_code">
<pre><span style="color: #000000;">ddjlasjdlas
</span><span style="color: #0000ff;">as</span><span style="color: #000000;">
dasdasjda</span></pre>
</div>
<p><a name="a2"></a>2、小标题2</p>
<p>正文正文正文正文正文</p>
<p><a name="a3"></a>3、小标题3</p>
<p>正文正文正文</p>
<p><a name="a4"></a>4、小标题4</p>
<p>正文正文正文</p>
<p> </p>
<h2>Excercises</h2>
<p><a name="b1"></a>① xxxxxx1</p>
<p>正文正文正文</p>
<p><a name="b2"></a>② xxx2</p>
<p>正文正文</p>
<p><a name="b3"></a>③ xx3</p>
<p>正文正文正文</p>
<p> </p>
3、自定义的规则
- “类似1、xx 2、xx”会被转化为目录中的第一类二级标题Notes
- “类似① xxx ② xx”会被转化为目录中的第二类二级标题Excercises
- 第二类二级标题必须全部为英文字符,且1或者①前面都不能有空格,①后面只能是英文空格
- Copy来的标题要先清除格式
4、Javascript代码
<!DOCTYPE html>
<html> <head>
<meta charset="UTF-8">
<title></title>
</head> <body>
<textarea id="big-textarea" placeholder="paste your origin html text here..." rows="30" cols="150"><h2>Notes</h2>
<h2>Exercises</h2></textarea>
<button id="big-button">Generate</button> <script type="text/javascript">
const button = document.querySelector('#big-button');
button.addEventListener('click', handleClick); function handleClick(event) {
const textarea = document.querySelector('#big-textarea');
let inputHtml = textarea.value;
textarea.value = generateDiy_right_menu(inputHtml);
}; function replaceAndRecordSmallTitles(str ,arr) {
const regex = /<p>(\d{1,2})\u3001([\d\w\s\u4e00-\u9fa5]+)/g;
const replaceAndRecordHelper = (_, index, smallTitle) => {
arr.push(smallTitle);
return `<p><a name="a${index}"></a>${index}、${smallTitle}`;
}
return str.replace(regex, replaceAndRecordHelper);
} function replaceAndRecordExercises(str, arr) {
const regex = /<p>([\u2460-\u2469])\s([\w\s]+)/g;
let exerciseCount = 1;
const replaceAndRecordHelper = (_, unicodeIndex, exerciseName) => {
arr.push(exerciseName);
return `<p><a name="b${exerciseCount++}"></a>${unicodeIndex} ${exerciseName}`;
}
return str.replace(regex, replaceAndRecordHelper);
} function htmlMenu(small_titles, exercise_names) {
const htmlMenuHead = '<div id="diy_right_menu">\n' +
'<h2>索引</h2>\n' + '<ul>\n<li>\n' + '<p>Notes</p>\n<ol>\n';
let htmlTitles = "";
for (let i = 0; i != small_titles.length; ++i) {
htmlTitles += `<li><a href="#a${i+1}">${small_titles[i]}</a></li>\n`;
}
let htmlExercise = "</ol></li>\n<li>\n<p>Exercises</p>\n<ol>\n";
for (let i = 0; i != exercise_names.length; ++i) {
htmlExercise += `<li><a href="#b${i+1}">${exercise_names[i]}</a></li>\n`;
}
const htmlMenuTail = '</ol></li>\n</ul>\n</div>\n';
const result = htmlMenuHead + htmlTitles + htmlExercise + htmlMenuTail;
return result;
} function generateDiy_right_menu(inputHtml) {
let result = inputHtml.slice();
// 用replace替换掉原文,顺便记录标题内容
const small_titles = [];
const exercise_names = [];
result = replaceAndRecordSmallTitles(result, small_titles);
result = replaceAndRecordExercises(result, exercise_names);
// 自动生成目录
if (result.slice(0, '<div id="diy'.length) != '<div id="diy') {
// 避免重复生成目录
result = htmlMenu(small_titles, exercise_names) + result;
}
return result;
}
</script>
</body> </html>
JavaScript笔记 #05# 用Regex辅助生成文章目录的更多相关文章
- JavaScript笔记 #08# 用Regex辅助生成文章目录 V2.0
索引 简介 测试用例 代码 简介 * 用Regex辅助生成文章目录 2.0 * 1.提高了功能的通用性(假定的文章格式更加普遍,即按照h2h3h4分级) * 2.改善了代码的可读性(稍微牺牲了一点点性 ...
- CSDN中根据文章自动生成文章目录
概述 CSDN中有根据文件内容中H标签在文章中自动生成文章目录,看起来比较专业,就想把它搬到自己的博客园中.类似下图 提取JS脚本 通过浏览器开发者工具(IE/Chrome)找到产生文章目录javas ...
- 使用autoc js生成文章目录(侧边)导航栏
介绍: autocjs 是一个专门用来生成文章目录(Table of Contents)导航的工具.autocjs 会查找文章指定区域中的所有 h1~h6 的标签,并自动分析文章的层次结构,生成文章的 ...
- WPS生成文章目录
WPS生成文章目录 1.引用–>插入目录...即可!
- 用React实现一个自动生成文章目录的组件
原文地址:小寒的博客 功能介绍 这个组件的效果呐,就是你在浏览这个页面的时候点击右上角的叉叉看到的那个文章目录. 功能很简单,就是根据文章内容自动生成这个目录,可以快速跳转. 需要的知识点 正则 do ...
- javascript笔记05:函数表达式和函数语句的区别
1.首先是函数语句: myfunc(); function myfunc() { //执行一些语句 } 当函数语句被定义的时候,在一个脚本代码被优先考虑,因此,无论该函数是定义之前或者定义之后都可以被 ...
- HelloDjango 第 11 篇:自动生成文章摘要
作者:HelloGitHub-追梦人物 文中涉及的示例代码,已同步更新到 HelloGitHub-Team 仓库 博客文章的模型有一个 excerpt 字段,这个字段用于存储文章的摘要.目前为止,还只 ...
- 使用office添加文章目录
当我们用word录入完文章,文章里有段落,段落里又有小标题,每一种标题的格式不尽相同,word为我们提供了相当丰富的标题格式,如:正文,无间隔,标题1,标题2,标题3,标题4,副标题,强调,要点... ...
- CSDN添加文章目录
在发表的文章中,系统根据文章中H1到H6标签自动生成文章目录. 一.发表文章的时候合理使用“标题”标签. 二.目录生成.只要在文章中使用了“标题1”这样的功能,就可以在博文开头看到文章的目录.
随机推荐
- 云计算概述及Centos7下安装kvm虚拟机
云计算(cloud computing)是基于互联网的相关服务的增加.使用和交付模式,通常涉及通过互联网来提供动态易扩展且经常是虚拟化的资源 云计算到底是什么? 按定义:云计算指的是一种使用模式,是基 ...
- 向数据库中添加数据,通过se16 不能添加,通过 代码可以添加的原因
1: 在向数据库中添加数据时,通过客户端se16 准备对 数据表进行添加数据,提示如下: 找了以下原因,如下: https://www.baidu.com/link?url=3yRtAfY1_9XG ...
- Pro*C介绍
内嵌SQL 概要 Pro*C语法 SQL 预处理指令 语句标号 宿主变量 基础 指针 结构 数组 指示器变量 数据类型同等化 动态SQL 事务 错误处理 SQLCA WHENEVER语句 Demo程序 ...
- [LeetCode] 364. Nested List Weight Sum II_Medium tag:DFS
Given a nested list of integers, return the sum of all integers in the list weighted by their depth. ...
- pd.concat/merge/join
pandas的拼接分为两种: 级联:pd.concat, pd.append 合并:pd.merge, pd.join 一.回顾numpy.concatenate 生成1个6*3的矩阵,一个2*3的矩 ...
- linux 标准输入输出 重定向
背景: 屏幕打印不一定都是从标准输出来的,也包括标准错误输出流stderr中的信息 文件描述符定义(系统定义了12个) 0 标准输入 1 标准输出 2 标准错误 0 默认键盘输入 1,2默认从屏幕 ...
- JAVA编程思想学习笔记5-chap13-15-斗之气5段
1.String对象不可变,一旦发生字符变换或者变长度,一定是新建了一个String private final char value[]; 2.字符串+与+=:唯二操作符重载 "aaa&q ...
- python list成员函数extend与append的区别
extend 原文解释,是以list中元素形式加入到列表中 extend list by appending elements from the iterable append(obj) 是将整个ob ...
- 福布斯最佳雇主榜:谷歌母公司Alphabet再登榜首 微软次之
http://www.sohu.com/a/259018538_114774 站长之家(ChinaZ.com) 10月12日 消息:在福布斯发布的最新全球最佳雇主榜单中,谷歌母公司Alphabet以满 ...
- STL之Vector容器
1.Vector容器 1)vector是将元素置于一个动态数组中加以管理的容器. 2)vector可以随机存取元素(支持索引值直接存取, 用[]操作符或at()方法,这个等下会详讲). 3)vecto ...