源码如下:
export const isHTMLTag = makeMap(
'html,body,base,head,link,meta,style,title,' +
'address,article,aside,footer,header,h1,h2,h3,h4,h5,h6,hgroup,nav,section,' +
'div,dd,dl,dt,figcaption,figure,picture,hr,img,li,main,ol,p,pre,ul,' +
'a,b,abbr,bdi,bdo,br,cite,code,data,dfn,em,i,kbd,mark,q,rp,rt,rtc,ruby,' +
's,samp,small,span,strong,sub,sup,time,u,var,wbr,area,audio,map,track,video,' +
'embed,object,param,source,canvas,script,noscript,del,ins,' +
'caption,col,colgroup,table,thead,tbody,td,th,tr,' +
'button,datalist,fieldset,form,input,label,legend,meter,optgroup,option,' +
'output,progress,select,textarea,' +
'details,dialog,menu,menuitem,summary,' +
'content,element,shadow,template,blockquote,iframe,tfoot'
)
描述:检查是否是HTML标签
源码分析
isHTMLTag
是一个使用 makeMap
生成的函数,可以在 shared/util.js 文件工具方法全解 中查看 makeMap
方法。
源码如下:
// this map is intentionally selective, only covering SVG elements that may
// contain child elements.
export const isSVG = makeMap(
'svg,animate,circle,clippath,cursor,defs,desc,ellipse,filter,font-face,' +
'foreignObject,g,glyph,image,line,marker,mask,missing-glyph,path,pattern,' +
'polygon,polyline,rect,switch,symbol,text,textpath,tspan,use,view',
true
)
描述:检查是否是SVG标签
源码分析
isSVG
是一个使用 makeMap
生成的函数,可以在 shared/util.js 文件工具方法全解 中查看 makeMap
方法。
源码如下:
export const isPreTag = (tag: ?string): boolean => tag === 'pre'
描述:检查给定的标签是否是 pre
标签
源码分析
通过 tag === 'pre'
进行判断。
源码如下:
export const isReservedTag = (tag: string): ?boolean => {
return isHTMLTag(tag) || isSVG(tag)
}
描述:检查给定的标签是否是保留的标签
源码分析
通过如下代码:
isHTMLTag(tag) || isSVG(tag)
判断一个标签是否是保留标签,我们可以知道,如果一个标签是 html
标签,或者是 svg
标签,那么这个标签即使保留标签。