递归手撕,JSON 字符串化和解析,加权树结构的字符串解析对象,解析并返回DOM 树结构(DOMParser),解析带有层级的文本

目录

[1 JSON 字符串化和解析](#1 JSON 字符串化和解析)

[2 加权树结构的字符串解析对象](#2 加权树结构的字符串解析对象)

[3. 解析并返回DOM 树结构](#3. 解析并返回DOM 树结构)

[4. 解析带有层级的文本](#4. 解析带有层级的文本)


1 JSON 字符串化和解析

javascript 复制代码
//  <!-- 实现一个函数,能够将自定义格式的字符串转换为 JSON 对象。
//      例如,给定字符串 'name: "Alice", age: 30',输出 { name: "Alice", age: 30 }。 -->
function digui(str){
 //首先 截取,的前后 然后截取:的前后
 let obj={}
 //str1='' x.slice()
 let arr=str.split(',')
 //['name:'alice],['age':'30']

 //考虑到alice外的引号和:后的空白没
 arr.map((item,index)=>{
  let [apple,pine]=item.split(': ').map((i)=>i.trim())
  pine=JSON.parse(pine)
  obj[apple]=pine

 })
 return obj

}
let str='name: "Alice", age: 30'
console.log(digui(str))

2 加权树结构的字符串解析对象

给定一个加权树结构的字符串,例如 '(A:3,(B:2,C:1))',解析为一个对象 { A: 3, B: 2, C: 1 }。

javascript 复制代码
//遇到左括号 递归 处理去掉逗号后 去掉冒号 第
  function digui(str){
//干脆去除所有括号 
let str2=''
for(let i=0;i<str.length;i++){
 
  if(str[i]!='(' && str[i]!=')')
  str2+=str[i]

}
let obj={}
let lines=str2.split(',').map(item => item.trim())
//[a:3],[b,3]
lines.forEach((item)=>{
  let [apple,pine]=item.split(':').map(item => item.trim())
  obj[apple]=pine

})
return obj


  }
  let str='(A:3,(B:2,C:1))'
  console.log(digui(str))

3. 解析并返回DOM 树结构

实现一个函数,能够解析简单的 HTML 字符串并返回 DOM 树结构。

javascript 复制代码
function apple(str){
let parser = new DOMParser()
let tryparser = parser.parseFromString(str,'text/html').body.firstChild
return tryparser
  }

  let str= "<div><span>Hello</span><p>World</p></div>";
  console.log(apple(str)); 

解析后返回的文档中包含一个完整的 HTML 文档结构(包含 <html><head><body> 标签),.body 选择其中的 <body> 元素。firstChild 选择 <body> 中的第一个子节点div。

text/html' 告诉浏览器和 JavaScript 解释器要将字符串按照 HTML 格式解析。

4. 解析带有层级的文本

编写一个函数将其解析为树形结构。

javascript 复制代码
function treee(str){
    let root={value:'root',children:[]}
  let st=[root]
  let lines=str.split('\n')
  lines.forEach(line=>{
let level=line.search(/\S/)
let node={value:line.trim(),children:[]}
while(st.length>level+1){
  st.pop()
}
st[st.length-1].children.push(node)
st.push(node)
  })
   return root 
  
  }
  const text = 'A\n  B\n    C\n  D';
    console.log(JSON.stringify(treee(text), null, 2));
  
相关推荐
小米渣的逆袭1 分钟前
Chrome Extension Script World(ISOLATED / MAIN)原理与适用场景
前端·javascript·chrome
微信开发api-视频号协议17 分钟前
Codex++安全边界探秘:从模型能力到风险防御
前端·安全·微信·企业微信
想你依然心痛44 分钟前
AtomCode 在前端开发中的实战体验:React + TypeScript 项目开发实录
前端·react.js·typescript
疯狂的魔鬼1 小时前
精确计算容器剩余视口高度:useAutoContainerFullHeight 的工程实践
前端·css·typescript
Esaka_Forever1 小时前
Python 与 JS (V8) 垃圾回收核心区别 + 底层根源分析
开发语言·javascript·jvm
用户059540174461 小时前
用了 3 个月 ChatGPT,才发现它一直在遗忘——用 Playwright 自动化验证记忆存储一致性
前端·css
玄玄子1 小时前
xss前端解决方案
前端·浏览器·xss
林希_Rachel_傻希希1 小时前
web性能优化之——AI总结视频
前端·javascript·面试
前端炒粉1 小时前
个人简历面经总结二
前端·网络·vue.js·react.js·面试
binbin_521 小时前
UIAbility 与 WindowStage:窗口创建、加载、销毁的完整链路
开发语言·javascript·深度学习·华为·harmonyos