通过图形API使用OneNote时遇到很多问题。
我了解OneNote所使用的不是纯HTML,而是需要将其前后转换为API……但这似乎并不那么复杂。
我正在处理内容中的标签,并且需要能够更新标签元素。没关系,除了我有缩进的项目(p或li)标签列表的地方。
已更新
如果我的onenote中有类似项目
我点击了图形api以通过图形api浏览器获取具有以下网址的内容
返回的html如下所示(请注意,缩进不存在)
<body data-absolute-enabled="true" style="font-family:Calibri;font-size:11pt">
<div id="div:{f115c5ea-0481-0f03-31aa-07b94321c323}{65}" style="position:absolute;left:264px;top:139px;width:624px">
<p id="p:{f115c5ea-0481-0f03-31aa-07b94321c323}{67}" data-tag="to-do" style="margin-top:0pt;margin-bottom:0pt">Item 1</p>
<p id="p:{f115c5ea-0481-0f03-31aa-07b94321c323}{74}" data-tag="to-do" style="margin-top:0pt;margin-bottom:0pt">Item 2</p>
<p id="p:{f115c5ea-0481-0f03-31aa-07b94321c323}{71}" data-tag="to-do" style="margin-top:0pt;margin-bottom:0pt">Item 2a</p>
<p id="p:{f115c5ea-0481-0f03-31aa-07b94321c323}{73}" data-tag="to-do" style="margin-top:0pt;margin-bottom:0pt">Item 2b</p>
<p id="p:{f115c5ea-0481-0f03-31aa-07b94321c323}{76}" data-tag="to-do" style="margin-top:0pt;margin-bottom:0pt">Item 3</p>
</div>
</body>
如果我修补具有此类子项的项以设置ID(将ID保留在其中……将其转换为永久性的数据ID),以供以后更新甚至关闭标签:
PATCH - https://graph.microsoft.com/beta/users/myname/onenote/pages/0-c9861926a1e8080518ca3750afa63800!1-2B303C571455A20B!102505/content?includeIDs=true
[
{
'target':'p:{f115c5ea-0481-0f03-31aa-07b94321c323}{74}',
'action':'replace',
'content':'<p id="p:{f115c5ea-0481-0f03-31aa-07b94321c323}{74}" data-tag="to-do" style="margin-top:0pt;margin-bottom:0pt">Item 2</p>'
}
]
将处理更新,然后将内容更新为此:
<body data-absolute-enabled="true" style="font-family:Calibri;font-size:11pt">
<div id="div:{f115c5ea-0481-0f03-31aa-07b94321c323}{65}" style="position:absolute;left:264px;top:139px;width:624px">
<p id="p:{f115c5ea-0481-0f03-31aa-07b94321c323}{67}" data-tag="to-do" style="margin-top:0pt;margin-bottom:0pt">Item 1</p>
<p id="p:{f115c5ea-0481-0f03-31aa-07b94321c323}{71}" data-tag="to-do" style="margin-top:0pt;margin-bottom:0pt">Item 2a</p>
<p id="p:{f115c5ea-0481-0f03-31aa-07b94321c323}{73}" data-tag="to-do" style="margin-top:0pt;margin-bottom:0pt">Item 2b</p>
<p id="p:{78cb2ca5-efec-4e6f-a763-12e9cac6a2b5}{2}" lang="en-US" data-tag="to-do" data-id="p:{f115c5ea-0481-0f03-31aa-07b94321c323}{74}" style="margin-top:0pt;margin-bottom:0pt">Item 2</p>
<p id="p:{f115c5ea-0481-0f03-31aa-07b94321c323}{76}" data-tag="to-do" style="margin-top:0pt;margin-bottom:0pt">Item 3</p>
</div>
</body>
嵌套的ul / ol项目本质上也是如此……我也尝试替换整个列表而不是单个项目,但是api调用错误而没有其他信息。嵌套的项目符号列表似乎也丢失了父项目符号。
我尝试批处理所有项目的所有更新,一次执行一次,以相反的顺序进行操作。
很有趣,如果我执行插入操作,则保留文本缩进和顺序,但是没有删除/删除补丁来清除旧文本...例如
[
{
'target':'p:{56d579c0-1203-0224-0587-6fe03fb82539}{34}',
'action':'insert',
'position':'before',
'content':'<p data-id="My_own_id" data-tag="to-do" style="margin-top:0pt;margin-bottom:0pt">Item 1</p>'
},
{
'target':'p:{56d579c0-1203-0224-0587-6fe03fb82539}{34}',
'action':'<tried replace or delete/remove hoping it was undocumented>',
'content':'<tried blank or just a span>'
}
]
其他问题包括
部分答案
这里是非项目符号列表问题的部分答案...感谢Codeye向我指出了正确的方向。
通过在现有元素之前插入我的元素,它可以保留顺序。
[
{
'target':'p:{20781e6d-ba99-4fca-9994-622720cad7f8}{249}',
'action':'insert',
'position':'before',
'content':'<p data-id="test" data-tag="to-do" style="margin-top:0pt;margin-bottom:0pt">Item 2</p>'
}
]
然后使用以下命令删除旧的,以保留格式。而且由于它是一个空的div,因此OneNote不会添加该元素。
[
{
'target':'p:{20781e6d-ba99-4fca-9994-622720cad7f8}{249}',
'action':'replace',
'content':'<div></div>'
}
]
答案 0 :(得分:1)
表格边框解决方案
使用表时,请使用border
属性代替style
。
API将为您返回带<table style="border:1px solid;border-collapse:collapse">...</table>
边框的表格。使用table.style.border
查找是否有边框(可以是1px或0px)。要为表格设置边框,请使用border
属性:<table border="1">...</table>
。
border
的{{1}}属性将被忽略。
答案 1 :(得分:0)
对于待办事项列表的特定问题,我可以确认缩进项目向上移动并与要更新的元素“分离”的问题。
看起来用缩进来更新列表的唯一可靠方法是替换整个列表(对表有类似的限制)。
在您的示例中,似乎需要更新所有5个段落以保持对齐。
如果这样不起作用,请尝试替换周围的div
[
{
'target':'div:{9dfa7be6-2de0-b802-01ae-20c164255f9d}{30}',
'action':'replace',
'content':'<div><p data-tag="to-do">Item 1</p>
<div><p data-tag="to-do">Item 2</p>
<ul>
<p data-tag="to-do:completed">Item 2a</p>
<p data-tag="to-do:completed">Item 2b</p>
</ul>
<div><p data-tag="to-do">Item 3</p>
<div><p data-tag="to-do">Item 4</p>
</div>'
}
]
关于如何删除元素,以下内容应该起作用
[{
'target': 'p:{f5837c83-d816-4337-ab6d-a52abde869a6}{13}',
'action': 'replace',
'content': '<br/>'
}]
这在列表中间不会起作用,因为您会遇到垂直间隙。