How to send markdown via REST API and render it on the frontend (React)
P粉166779363
P粉166779363 2024-02-26 13:42:25
0
2
398

So I tried converting the Markdown file and sending it via Rest API and then rendering it on the frontend. The problem is that newlines and other content are lost when trying to convert them back.

How do I render it in a way that preserves the original markdown?

Is there a standard way to do this?

Tried converting markdown via json.stringify, sent via api, tried converting it back to markdown, but no longer works like the original.

P粉166779363
P粉166779363

reply all(2)
P粉418214279

You can add everything in

 tag as following

   This is
   some code
   Ajson:
   {
     key: value
   }

In <pre> tags, the text preserves spaces and newlines, so it will appear exactly as written in the HTML source code.

P粉423694341

You can send the original file as a string, or if this is not an option, you can use this function to format the object:

const object = {a:[15,3457,15,"afbsv",[4,34,36],{
  l: "dsfvszd",
  qwe: 238475463,
  iuggbsf: ["AEfs",],
  afafwwa:{afafwafaw:{r:"4"}}
}]}

document.write(`
${format(object)}
`); function format (object) { let result = ""; ProcessObject(Object, 2); Function processObject(object, depth, isObjectValue = false, TrailingComma = "") { if (array . isArray (object)) { Result = `${isObjectValue ? " " : "
" " ".repeat(depth - 2)}[`; for (let i = 0; i ${" ".repeat(depth)}"${element}"${trailingComma}`; rest; Case number": Result = `
${" ".repeat(depth) element}${trailingComma}`; rest; } } Result = `
${" ".repeat(depth - 2)}]${trailingComma}`; } other { Result = `${isObjectValue ? " " : "
" " ".repeat(depth - 2)}{`; Let keyIndex = 0, keyCount = Object.keys(object).length; for (key in object) { constant value = object[key], Trailing comma = keyIndex === keyCount ? "": ","; switch (value type) { Case "object": Result = `
${" ".repeat(depth)}"${key}":`; processObject(value, depth2, true, TrailingComma); rest; Case "string": Result = `
${" ".repeat(depth)}"${key}": "${value}"${trailingComma}`; rest; Case number": Result = `
${" ".repeat(depth)}"${key}": ${value}${trailingComma}`; rest; } } Result = `
${" ".repeat(depth - 2)}}${trailingComma}`; } } return results; }
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template