mirror of
https://github.com/doocs/md.git
synced 2025-01-23 04:14:42 +08:00
fix: export to html render abnormal (#468)
All checks were successful
Build and Deploy / build-and-deploy (push) Has been skipped
All checks were successful
Build and Deploy / build-and-deploy (push) Has been skipped
This commit is contained in:
parent
2ae75ab76e
commit
a62fa1f29b
14
README.md
14
README.md
@ -78,19 +78,19 @@ Markdown 文档自动即时渲染为微信图文,让你不再为微信文章
|
|||||||
示例代码:
|
示例代码:
|
||||||
|
|
||||||
```js
|
```js
|
||||||
const { file, util, okCb, errCb } = CUSTOM_ARG;
|
const { file, util, okCb, errCb } = CUSTOM_ARG
|
||||||
const param = new FormData();
|
const param = new FormData()
|
||||||
param.append(`file`, file);
|
param.append(`file`, file)
|
||||||
util.axios
|
util.axios
|
||||||
.post(`http://127.0.0.1:9000/upload`, param, {
|
.post(`http://127.0.0.1:9000/upload`, param, {
|
||||||
headers: { "Content-Type": `multipart/form-data` },
|
headers: { 'Content-Type': `multipart/form-data` },
|
||||||
})
|
})
|
||||||
.then((res) => {
|
.then((res) => {
|
||||||
okCb(res.url);
|
okCb(res.url)
|
||||||
})
|
})
|
||||||
.catch((err) => {
|
.catch((err) => {
|
||||||
errCb(err);
|
errCb(err)
|
||||||
});
|
})
|
||||||
|
|
||||||
// 提供的可用参数:
|
// 提供的可用参数:
|
||||||
// CUSTOM_ARG = {
|
// CUSTOM_ARG = {
|
||||||
|
@ -335,7 +335,7 @@ export const useStore = defineStore(`store`, () => {
|
|||||||
|
|
||||||
// 导出编辑器内容为 HTML,并且下载到本地
|
// 导出编辑器内容为 HTML,并且下载到本地
|
||||||
const exportEditorContent2HTML = () => {
|
const exportEditorContent2HTML = () => {
|
||||||
exportHTML()
|
exportHTML(primaryColor.value)
|
||||||
document.querySelector(`#output`)!.innerHTML = output.value
|
document.querySelector(`#output`)!.innerHTML = output.value
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -180,10 +180,16 @@ export function downloadMD(doc: string) {
|
|||||||
/**
|
/**
|
||||||
* 导出 HTML 生成内容
|
* 导出 HTML 生成内容
|
||||||
*/
|
*/
|
||||||
export function exportHTML() {
|
export function exportHTML(primaryColor: string) {
|
||||||
const element = document.querySelector(`#output`)!
|
const element = document.querySelector(`#output`)!
|
||||||
|
|
||||||
setStyles(element)
|
setStyles(element)
|
||||||
|
|
||||||
const htmlStr = element.innerHTML
|
const htmlStr = element.innerHTML
|
||||||
|
.replaceAll(`var(--el-text-color-regular)`, `#3f3f3f`)
|
||||||
|
.replaceAll(`var(--blockquote-background)`, `#f7f7f7`)
|
||||||
|
.replaceAll(`var(--md-primary-color)`, primaryColor)
|
||||||
|
.replaceAll(/--md-primary-color:.+?;/g, ``)
|
||||||
|
|
||||||
const downLink = document.createElement(`a`)
|
const downLink = document.createElement(`a`)
|
||||||
|
|
||||||
@ -205,13 +211,21 @@ export function exportHTML() {
|
|||||||
* @param {排除的属性} excludes 如果某些属性对结果有不良影响,可以使用这个参数来排除
|
* @param {排除的属性} excludes 如果某些属性对结果有不良影响,可以使用这个参数来排除
|
||||||
* @returns 行内样式拼接结果
|
* @returns 行内样式拼接结果
|
||||||
*/
|
*/
|
||||||
function getElementStyles(element: Element, excludes = [`width`, `height`]) {
|
function getElementStyles(element: Element, excludes = [`width`, `height`, `inlineSize`, `webkitLogicalWidth`, `webkitLogicalHeight`]) {
|
||||||
const styles = getComputedStyle(element, null)
|
const styles = getComputedStyle(element, null)
|
||||||
return Object.entries(styles)
|
return Object.entries(styles)
|
||||||
.filter(
|
.filter(
|
||||||
([key]) => styles.getPropertyValue(key) && !excludes.includes(key),
|
([key]) => {
|
||||||
|
// 将驼峰转换为短横线格式
|
||||||
|
const kebabKey = key.replace(/[A-Z]/g, match => `-${match.toLowerCase()}`)
|
||||||
|
return styles.getPropertyValue(kebabKey) && !excludes.includes(key)
|
||||||
|
},
|
||||||
)
|
)
|
||||||
.map(([key, value]) => `${key}:${value};`)
|
.map(([key, value]) => {
|
||||||
|
// 将驼峰转换为短横线格式
|
||||||
|
const kebabKey = key.replace(/[A-Z]/g, match => `-${match.toLowerCase()}`)
|
||||||
|
return `${kebabKey}:${value};`
|
||||||
|
})
|
||||||
.join(``)
|
.join(``)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user