在学外语,做笔记梳理时,想给句子加上音频,已经有句子文本和音频文件名的对应文本,怎么能快速将句子设置为音频的锚文本,并点击锚文本即播放呢?
直接插入音频后,会直接显示音频控件,占据的位置太大了,而且也没找到在哪里设置锚文本。
通过超链接设置句子为锚文本后,点击文本会在另一个标签弹出音频控件,然后再点击才能播放,而且要一句一句去设置填写,也比较麻烦。
想问问有没有能直接通过某种格式把我的句子和音频直接转换成点击即播放的形式吗?
在学外语,做笔记梳理时,想给句子加上音频,已经有句子文本和音频文件名的对应文本,怎么能快速将句子设置为音频的锚文本,并点击锚文本即播放呢?
直接插入音频后,会直接显示音频控件,占据的位置太大了,而且也没找到在哪里设置锚文本。
通过超链接设置句子为锚文本后,点击文本会在另一个标签弹出音频控件,然后再点击才能播放,而且要一句一句去设置填写,也比较麻烦。
想问问有没有能直接通过某种格式把我的句子和音频直接转换成点击即播放的形式吗?
方法一,使用 HTML 块实现(编辑器输入 /html,把代码粘贴到对话框即可)
需要开启 设置 》编辑器 》允许执行 HTML 块内脚本
<!-- mp3 列表 -->
<a onclick="playAudio(event,this.href);" href="file:///youpath/demo1.mp3" >demo1</a><br>
<a onclick="playAudio(event,this.href);" href="file:///youpath/demo2.mp3">demo2</a><br>
<!-- js 代码 -->
<script>
var audio;
function playAudio(event,mp3) {
event.preventDefault();
if(!audio){
audio = document.createElement('audio');
document.body.appendChild(audio);
}
audio.src = mp3;
audio.play();
}
</script>
方法二,使用 SQL 查询块实现(编辑器输入 {{}},把代码粘贴到对话框即可)
//!js
return (async () => {
// 这里配置mp3列表
const mp3List = {
"demo1": "file:///youpath/demo1.mp3",
"demo2": "file:///youpath/demo2.mp3",
};
// 代码逻辑区
let list = [];
for (let key in mp3List) {
list.push(`<div><span data-type="a" data-mp3="${mp3List[key]}">${key}</span></div>`);
}
return render(`<div class="mp3List-wrapper">${list.join('')}</div>`, (embed) => {
embed.querySelector('.mp3List-wrapper').addEventListener('click', (event) => {
const mp3 = event.target?.dataset?.mp3;
if (mp3) {
playAudio(mp3);
}
});
});
var audio;
function playAudio(mp3) {
if(!audio){
audio = document.createElement('audio');
document.body.appendChild(audio);
}
audio.src = mp3;
audio.play();
}
function render(html, callback) {
onRender('.b3-form__space--small').then((container) => {
const wysiwygEmbed = container.parentElement;
wysiwygEmbed.style.backgroundColor = 'transparent';
wysiwygEmbed.style.borderLeft='none';
container.outerHTML = html;
if(callback) callback(wysiwygEmbed);
});
return [];
}
function onRender(selector) {
return new Promise(resolve => {
const check = () => {
let el = item.querySelector(selector);
if (el) resolve(el); else requestAnimationFrame(check);
};
check();
});
}
})();
效果
你的理解没错,思源的 HTML 没有其他笔记的那么直观,虽然思源不支持手动输入 HTML 代码,但粘贴 HTML 代码是可以的,所以建议你在外部编辑好后直接粘贴到文档里。
但要注意思源的 HTML 代码必须以一个 div 标签包裹才行,比如
<div>
<p>hello world</p>
<p>hello world</p>
</div>
这样粘贴就没问题,不会转换为实体
但下面这种粘贴就会转换为 HTML 实体
<p>hello world</p>
<p>hello world</p>
或
<ul>
<li>hello world</li>
<li>hello world</li>
</ul>
解决办法就是在他们前面添加 div 包裹就没问题了,比如改成
<div>
<p>hello world</p>
<p>hello world</p>
</div>
或
<div>
<ul>
<li>hello world</li>
<li>hello world</li>
</ul>
</div>
有了上面的知识,那么批量修改你的代码就很方便了,比如修改成下面这样,然后再粘贴
<div>
<div>英语学习</div>
<script>
var audio;
function playAudio(event,mp3) {
event.preventDefault();
if(!audio){
audio = document.createElement('audio');
document.body.appendChild(audio);
}
audio.src = mp3;
audio.play();
}
</script>
</div>
描述1
<div><a onclick="playAudio(event,this.href);" href="file:///yourpath/demo1.mp3" >demo1</a></div>
描述2
<div><a onclick="playAudio(event,this.href);" href="file:///yourpath/demo2.mp3" >demo2</a></div>
这里的 <script>
标签页可以放到任意一个链接的 HTML 代码块中,这样就不用单独的占一个块了。
如果你的版本不支持,也可以安装 vscode 插件,然后使用源码粘贴。
当然,还有好的方法,比如通过插件或 js 片段魔改 audio 块等,太过复杂,仅供兴趣研究。
Mozilla Firefox 中文俗称“火狐”(正式缩写为 Fx 或 fx,非正式缩写为 FF),是一个开源的网页浏览器,使用 Gecko 排版引擎,支持多种操作系统,如 Windows、OSX 及 Linux 等。
Log4j 是 Apache 开源的一款使用广泛的 Java 日志组件。
互联网(Internet),又称网际网络,或音译因特网、英特网。互联网始于 1969 年美国的阿帕网,是网络与网络之间所串连成的庞大网络,这些网络以一组通用的协议相连,形成逻辑上的单一巨大国际网络。
HHKB 是富士通的 Happy Hacking 系列电容键盘。电容键盘即无接点静电电容式键盘(Capacitive Keyboard)。
强迫症(OCD)属于焦虑障碍的一种类型,是一组以强迫思维和强迫行为为主要临床表现的神经精神疾病,其特点为有意识的强迫和反强迫并存,一些毫无意义、甚至违背自己意愿的想法或冲动反反复复侵入患者的日常生活。
思源笔记是一款隐私优先的个人知识管理系统,支持完全离线使用,同时也支持端到端加密同步。
融合块、大纲和双向链接,重构你的思维。
微软是一家美国跨国科技公司,也是世界 PC 软件开发的先导,由比尔·盖茨与保罗·艾伦创办于 1975 年,公司总部设立在华盛顿州的雷德蒙德(Redmond,邻近西雅图)。以研发、制造、授权和提供广泛的电脑软件服务业务为主。
Openfire 是开源的、基于可拓展通讯和表示协议 (XMPP)、采用 Java 编程语言开发的实时协作服务器。Openfire 的效率很高,单台服务器可支持上万并发用户。
这是一个不能说的秘密。
Java 是一种可以撰写跨平台应用软件的面向对象的程序设计语言,是由 Sun Microsystems 公司于 1995 年 5 月推出的。Java 技术具有卓越的通用性、高效性、平台移植性和安全性。
Vim 是类 UNIX 系统文本编辑器 Vi 的加强版本,加入了更多特性来帮助编辑源代码。Vim 的部分增强功能包括文件比较(vimdiff)、语法高亮、全面的帮助系统、本地脚本(Vimscript)和便于选择的可视化模式。
Latke 是一款以 JSON 为主的 Java Web 框架。
Shell 脚本与 Windows/Dos 下的批处理相似,也就是用各类命令预先放入到一个文件中,方便一次性执行的一个程序文件,主要是方便管理员进行设置或者管理用的。但是它比 Windows 下的批处理更强大,比用其他编程程序编辑的程序效率更高,因为它使用了 Linux/Unix 下的命令。
宋真宗赵恒曾经说过:“书中自有黄金屋,书中自有颜如玉。”
OAuth 协议为用户资源的授权提供了一个安全的、开放而又简易的标准。与以往的授权方式不同之处是 oAuth 的授权不会使第三方触及到用户的帐号信息(如用户名与密码),即第三方无需使用用户的用户名与密码就可以申请获得该用户资源的授权,因此 oAuth 是安全的。oAuth 是 Open Authorization 的简写。
Swagger 是一款非常流行的 API 开发工具,它遵循 OpenAPI Specification(这是一种通用的、和编程语言无关的 API 描述规范)。Swagger 贯穿整个 API 生命周期,如 API 的设计、编写文档、测试和部署。
Kafka 是一种高吞吐量的分布式发布订阅消息系统,它可以处理消费者规模的网站中的所有动作流数据。 这种动作(网页浏览,搜索和其他用户的行动)是现代系统中许多功能的基础。 这些数据通常是由于吞吐量的要求而通过处理日志和日志聚合来解决。
TensorFlow 是一个采用数据流图(data flow graphs),用于数值计算的开源软件库。节点(Nodes)在图中表示数学操作,图中的线(edges)则表示在节点间相互联系的多维数据数组,即张量(tensor)。
Go 语言是 Google 推出的一种全新的编程语言,可以在不损失应用程序性能的情况下降低代码的复杂性。谷歌首席软件工程师罗布派克(Rob Pike)说:我们之所以开发 Go,是因为过去 10 多年间软件开发的难度令人沮丧。Go 是谷歌 2009 发布的第二款编程语言。
宕机,多指一些网站、游戏、网络应用等服务器一种区别于正常运行的状态,也叫“Down 机”、“当机”或“死机”。宕机状态不仅仅是指服务器“挂掉了”、“死机了”状态,也包括服务器假死、停用、关闭等一些原因而导致出现的不能够正常运行的状态。
Docker 是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的操作系统上。容器完全使用沙箱机制,几乎没有性能开销,可以很容易地在机器和数据中心中运行。
Hibernate 是一个开放源代码的对象关系映射框架,它对 JDBC 进行了非常轻量级的对象封装,使得 Java 程序员可以随心所欲的使用对象编程思维来操纵数据库。
SMTP(Simple Mail Transfer Protocol)即简单邮件传输协议,它是一组用于由源地址到目的地址传送邮件的规则,由它来控制信件的中转方式。SMTP 协议属于 TCP/IP 协议簇,它帮助每台计算机在发送或中转信件时找到下一个目的地。
Pipe 是一款小而美的开源博客平台。Pipe 有着非常活跃的社区,可将文章作为帖子推送到社区,来自社区的回帖将作为博客评论进行联动(具体细节请浏览 B3log 构思 - 分布式社区网络)。
这是一种全新的网络社区体验,让热爱记录和分享的你不再感到孤单!
VirtualBox 是一款开源虚拟机软件,最早由德国 Innotek 公司开发,由 Sun Microsystems 公司出品的软件,使用 Qt 编写,在 Sun 被 Oracle 收购后正式更名成 Oracle VM VirtualBox。
RabbitMQ 是一个开源的 AMQP 实现,服务器端用 Erlang 语言编写,支持多种语言客户端,如:Python、Ruby、.NET、Java、C、PHP、ActionScript 等。用于在分布式系统中存储转发消息,在易用性、扩展性、高可用性等方面表现不俗。