mirror of
https://github.com/d0zingcat/NotionNext.git
synced 2026-05-14 07:26:52 +00:00
58 lines
1.7 KiB
JavaScript
58 lines
1.7 KiB
JavaScript
import { useEffect } from 'react'
|
||
|
||
/**
|
||
* 字数统计
|
||
* @returns
|
||
*/
|
||
export default function WordCount() {
|
||
useEffect(() => {
|
||
countWords()
|
||
})
|
||
|
||
return <div id='wordCountWrapper' className='flex justify-center my-auto font-light'>
|
||
<i className='mr-1 fas fa-file-word my-auto' /> <span className='hidden md:block'>本文字数</span> <strong id='wordCount'>0</strong> | <i className='mr-1 fas fa-clock my-auto' /> <span className='hidden md:block'>阅读时长 ≈</span> <strong id='readTime'>0</strong> 分钟
|
||
</div>
|
||
}
|
||
|
||
/**
|
||
* 更新字数统计和阅读时间
|
||
*/
|
||
function countWords() {
|
||
const articleText = deleteHtmlTag(document.getElementById('notion-article')?.innerHTML)
|
||
const wordCount = fnGetCpmisWords(articleText)
|
||
// 阅读速度 300-500每分钟
|
||
document.getElementById('wordCount').innerHTML = wordCount
|
||
document.getElementById('readTime').innerHTML = Math.floor(wordCount / 400) + 1
|
||
const wordCountWrapper = document.getElementById('wordCountWrapper')
|
||
wordCountWrapper.classList.remove('hidden')
|
||
}
|
||
|
||
// 去除html标签
|
||
function deleteHtmlTag(str) {
|
||
if (!str) {
|
||
return ''
|
||
}
|
||
str = str.replace(/<[^>]+>|&[^>]+;/g, '').trim()// 去掉所有的html标签和 之类的特殊符合
|
||
return str
|
||
}
|
||
|
||
// 用word方式计算正文字数
|
||
function fnGetCpmisWords(str) {
|
||
if (!str) {
|
||
return 0
|
||
}
|
||
let sLen = 0
|
||
try {
|
||
// eslint-disable-next-line no-irregular-whitespace
|
||
str = str.replace(/(\r\n+|\s+| +)/g, '龘')
|
||
// eslint-disable-next-line no-control-regex
|
||
str = str.replace(/[\x00-\xff]/g, 'm')
|
||
str = str.replace(/m+/g, '*')
|
||
str = str.replace(/龘+/g, '')
|
||
sLen = str.length
|
||
} catch (e) {
|
||
|
||
}
|
||
return sLen
|
||
}
|