我正在尝试从Visio中创建的SVG文件中提取自定义属性。我尝试使用jQuery,如果我使用“ g”作为选择器,则会获得节点列表,但是我试图获取的子级并提取v:name和v.val之类的属性值。
[任何人都可以建议一个好方法来做到这一点。谢谢您的帮助。
<g id="shape407-1000" v:mID="407" v:groupContext="shape" v:layerMember="0" transform="translate(-7.2,-10.2789)">
<title>Horizontal.411</title>
<desc>A</desc>
<v:custProps>
<v:cp v:nameU="LPrec" v:lbl="Precision" v:type="1" v:format="0;0.0;0.00;0.000;0.0000" v:invis="false"
v:langID="1033" v:val="VT4(0.00)"/>
<v:cp v:nameU="LUnits" v:lbl="Units" v:type="1"
v:format="Use Drawing Page's Units;Feet-Inch (1'-0");Feet (1.00');Inches;Feet (1.00ft);Miles;Millimeters;Centimeters;Meters;Kilometers"
v:invis="false" v:langID="1033" v:val="VT4(Use Drawing Page's Units)"/>
<v:cp v:nameU="ShowUnits" v:lbl="Units Display" v:type="1" v:format="Don't Show Units;Show Units"
v:invis="false" v:langID="1033" v:val="VT4(Don't Show Units)"/>
<v:cp v:nameU="Extensions" v:lbl="Extension Lines" v:type="1" v:format="Both;End only;Begin only;Neither"
v:invis="true" v:langID="1033" v:val="VT4(Both)"/>
<v:cp v:nameU="Angle" v:type="2" v:invis="false" v:langID="1033" v:val="VT0(0):37"/>
<v:cp v:nameU="Width" v:lbl="Input" v:prompt="Enter Width" v:type="0" v:langID="1033" v:val="VT4(In)"/>
<v:cp v:nameU="Class" v:lbl="Units_" v:type="0" v:langID="1033" v:val="VT4(In)"/>
</v:custProps>
<v:userDefs>
<v:ud v:nameU="AntiScale" v:val="VT0(1):26"/>
<v:ud v:nameU="LUnitsFactor" v:val="VT0(0):19"/>
<v:ud v:nameU="FormatString" v:val="VT4(0.00)"/>
<v:ud v:nameU="LengthText" v:val="VT4(1.00)"/>
<v:ud v:nameU="Length" v:val="VT0(1):19"/>
<v:ud v:nameU="LPFString" v:prompt="Linear Precision Formatting String" v:val="VT4(0.00)"/>
<v:ud v:nameU="LPrec" v:val="VT0(2):26"/>
<v:ud v:nameU="LPrecInd" v:val="VT0(2):26"/>
<v:ud v:nameU="LPrecVal" v:val="VT4(0.00)"/>
<v:ud v:nameU="LUnits" v:val="VT0(0):26"/>
<v:ud v:nameU="LUnitsInd" v:prompt="0=Dwg, 1=Arch, 2=Dec Ft, 3+ = other" v:val="VT0(0):26"/>
<v:ud v:nameU="LUnitsVal" v:val="VT4(Use Drawing Page's Units)"/>
<v:ud v:nameU="ShowUnits" v:val="VT0(0):26"/>
<v:ud v:nameU="ShowUnitsInd" v:val="VT0(0):26"/>
<v:ud v:nameU="ShowUnitsVal" v:val="VT4(Don't Show Units)"/>
<v:ud v:nameU="FeetInch" v:val="VT0(0):26"/>
<v:ud v:nameU="Feet" v:val="VT0(0):26"/>
<v:ud v:nameU="Inch" v:val="VT0(0):26"/>
<v:ud v:nameU="InchPrec" v:val="VT0(16):26"/>
<v:ud v:nameU="LocEndX" v:val="VT0(1):1"/>
<v:ud v:nameU="LocEndY" v:val="VT0(0):1"/>
<v:ud v:nameU="visObjectType" v:val="VT0(105):26"/>
<v:ud v:nameU="DrawingUnitFactor" v:val="VT0(0):19"/>
<v:ud v:nameU="visVersion" v:val="VT0(15):26"/>
<v:ud v:nameU="LUnitsFactor" v:prompt="" v:val="VT0(0):0"/>
<v:ud v:nameU="LengthText" v:prompt="" v:val="VT4(0.70)"/>
<v:ud v:nameU="Length" v:prompt="" v:val="VT0(0.7):0"/>
<v:ud v:nameU="LocEndX" v:prompt="" v:val="VT0(-0.7):1"/>
<v:ud v:nameU="DrawingUnitFactor" v:prompt="" v:val="VT0(0):0"/>
</v:userDefs>
<v:textBlock v:margins="rect(0,0,0,0)"/>
<v:textRect cx="25.2" cy="496.058" width="4.84" height="7.20349"/>
<path d="M50.4 490.06 L50.4 517.74 L50.4 490.06 ZM0 490.06 L0 517.74 L0 490.06 Z" class="st20"/>
<path d="M50.4 490.06 L50.4 517.74 L50.4 490.06" class="st21"/>
<path d="M0 490.06 L0 517.74 L0 490.06" class="st21"/>
<path d="M25.2 496.06 L6.12 496.06" class="st22"/>
<path d="M25.2 496.06 L44.28 496.06" class="st22"/>
<rect v:rectContext="textBkgnd" x="23.4641" y="492.458" width="3.47168" height="7.20016" class="st24"/>
<text x="23.46" y="497.86" class="st25" v:langID="1033"><v:paragraph v:horizAlign="1"/><v:tabList/>A</text> </g>
<g id="shape408-1013" v:mID="408" v:groupContext="shape" v:layerMember="0"
transform="translate(-376.737,435.022) rotate(-90)">
<title>Vertical</title>
<desc>B</desc>
<v:custProps>
<v:cp v:nameU="LPrec" v:lbl="Precision" v:type="1" v:format="0;0.0;0.00;0.000;0.0000" v:invis="false"
v:langID="1033" v:val="VT4(0.00)"/>
<v:cp v:nameU="LUnits" v:lbl="Units" v:type="1"
v:format="Use Drawing Page's Units;Feet-Inch (1'-0");Feet (1.00');Inches;Feet (1.00ft);Miles;Millimeters;Centimeters;Meters;Kilometers"
v:invis="false" v:langID="1033" v:val="VT4(Use Drawing Page's Units)"/>
<v:cp v:nameU="ShowUnits" v:lbl="Units Display" v:type="1" v:format="Don't Show Units;Show Units"
v:invis="false" v:langID="1033" v:val="VT4(Don't Show Units)"/>
<v:cp v:nameU="Extensions" v:lbl="Extension Lines" v:type="1" v:format="Both;End only;Begin only;Neither"
v:invis="true" v:langID="1033" v:val="VT4(Both)"/>
<v:cp v:nameU="Angle" v:type="2" v:invis="false" v:langID="1033" v:val="VT0(1.5707963267949):37"/>
<v:cp v:nameU="Angle" v:lbl="" v:prompt="" v:type="0" v:format="" v:sortKey="" v:invis="false" v:ask="false"
v:langID="0" v:cal="0" v:val="VT0(1.5707963267949):32"/>
<v:cp v:nameU="Hight" v:lbl="Input" v:prompt="Enter Height" v:type="0" v:langID="1033" v:val="VT4(ft)"/>
<v:cp v:nameU="Class" v:lbl="Units_" v:type="0" v:langID="1033" v:val="VT4(ft)"/>
</v:custProps>
<g id="shape407-1000" v:mID="407" v:groupContext="shape" v:layerMember="0" transform="translate(-7.2,-10.2789)">
<title>Horizontal.411</title>
<desc>A</desc>
<v:custProps>
<v:cp v:nameU="LPrec" v:lbl="Precision" v:type="1" v:format="0;0.0;0.00;0.000;0.0000" v:invis="false"
v:langID="1033" v:val="VT4(0.00)"/>
<v:cp v:nameU="LUnits" v:lbl="Units" v:type="1"
v:format="Use Drawing Page's Units;Feet-Inch (1'-0");Feet (1.00');Inches;Feet (1.00ft);Miles;Millimeters;Centimeters;Meters;Kilometers"
v:invis="false" v:langID="1033" v:val="VT4(Use Drawing Page's Units)"/>
<v:cp v:nameU="ShowUnits" v:lbl="Units Display" v:type="1" v:format="Don't Show Units;Show Units"
v:invis="false" v:langID="1033" v:val="VT4(Don't Show Units)"/>
<v:cp v:nameU="Extensions" v:lbl="Extension Lines" v:type="1" v:format="Both;End only;Begin only;Neither"
v:invis="true" v:langID="1033" v:val="VT4(Both)"/>
<v:cp v:nameU="Angle" v:type="2" v:invis="false" v:langID="1033" v:val="VT0(0):37"/>
<v:cp v:nameU="Width" v:lbl="Input" v:prompt="Enter Width" v:type="0" v:langID="1033" v:val="VT4(In)"/>
<v:cp v:nameU="Class" v:lbl="Units_" v:type="0" v:langID="1033" v:val="VT4(In)"/>
</v:custProps>
<v:userDefs>
<v:ud v:nameU="AntiScale" v:val="VT0(1):26"/>
<v:ud v:nameU="LUnitsFactor" v:val="VT0(0):19"/>
<v:ud v:nameU="FormatString" v:val="VT4(0.00)"/>
<v:ud v:nameU="LengthText" v:val="VT4(1.00)"/>
<v:ud v:nameU="Length" v:val="VT0(1):19"/>
<v:ud v:nameU="LPFString" v:prompt="Linear Precision Formatting String" v:val="VT4(0.00)"/>
<v:ud v:nameU="LPrec" v:val="VT0(2):26"/>
<v:ud v:nameU="LPrecInd" v:val="VT0(2):26"/>
<v:ud v:nameU="LPrecVal" v:val="VT4(0.00)"/>
<v:ud v:nameU="LUnits" v:val="VT0(0):26"/>
<v:ud v:nameU="LUnitsInd" v:prompt="0=Dwg, 1=Arch, 2=Dec Ft, 3+ = other" v:val="VT0(0):26"/>
<v:ud v:nameU="LUnitsVal" v:val="VT4(Use Drawing Page's Units)"/>
<v:ud v:nameU="ShowUnits" v:val="VT0(0):26"/>
<v:ud v:nameU="ShowUnitsInd" v:val="VT0(0):26"/>
<v:ud v:nameU="ShowUnitsVal" v:val="VT4(Don't Show Units)"/>
<v:ud v:nameU="FeetInch" v:val="VT0(0):26"/>
<v:ud v:nameU="Feet" v:val="VT0(0):26"/>
<v:ud v:nameU="Inch" v:val="VT0(0):26"/>
<v:ud v:nameU="InchPrec" v:val="VT0(16):26"/>
<v:ud v:nameU="LocEndX" v:val="VT0(1):1"/>
<v:ud v:nameU="LocEndY" v:val="VT0(0):1"/>
<v:ud v:nameU="visObjectType" v:val="VT0(105):26"/>
<v:ud v:nameU="DrawingUnitFactor" v:val="VT0(0):19"/>
<v:ud v:nameU="visVersion" v:val="VT0(15):26"/>
<v:ud v:nameU="LUnitsFactor" v:prompt="" v:val="VT0(0):0"/>
<v:ud v:nameU="LengthText" v:prompt="" v:val="VT4(0.70)"/>
<v:ud v:nameU="Length" v:prompt="" v:val="VT0(0.7):0"/>
<v:ud v:nameU="LocEndX" v:prompt="" v:val="VT0(-0.7):1"/>
<v:ud v:nameU="DrawingUnitFactor" v:prompt="" v:val="VT0(0):0"/>
</v:userDefs>
<v:textBlock v:margins="rect(0,0,0,0)"/>
<v:textRect cx="25.2" cy="496.058" width="4.84" height="7.20349"/>
<path d="M50.4 490.06 L50.4 517.74 L50.4 490.06 ZM0 490.06 L0 517.74 L0 490.06 Z" class="st20"/>
<path d="M50.4 490.06 L50.4 517.74 L50.4 490.06" class="st21"/>
<path d="M0 490.06 L0 517.74 L0 490.06" class="st21"/>
<path d="M25.2 496.06 L6.12 496.06" class="st22"/>
<path d="M25.2 496.06 L44.28 496.06" class="st22"/>
<rect v:rectContext="textBkgnd" x="23.4641" y="492.458" width="3.47168" height="7.20016" class="st24"/>
<text x="23.46" y="497.86" class="st25" v:langID="1033"><v:paragraph v:horizAlign="1"/><v:tabList/>A</text> </g>
<g id="shape408-1013" v:mID="408" v:groupContext="shape" v:layerMember="0"
transform="translate(-376.737,435.022) rotate(-90)">
<title>Vertical</title>
<desc>B</desc>
<v:custProps>
<v:cp v:nameU="LPrec" v:lbl="Precision" v:type="1" v:format="0;0.0;0.00;0.000;0.0000" v:invis="false"
v:langID="1033" v:val="VT4(0.00)"/>
<v:cp v:nameU="LUnits" v:lbl="Units" v:type="1"
v:format="Use Drawing Page's Units;Feet-Inch (1'-0");Feet (1.00');Inches;Feet (1.00ft);Miles;Millimeters;Centimeters;Meters;Kilometers"
v:invis="false" v:langID="1033" v:val="VT4(Use Drawing Page's Units)"/>
<v:cp v:nameU="ShowUnits" v:lbl="Units Display" v:type="1" v:format="Don't Show Units;Show Units"
v:invis="false" v:langID="1033" v:val="VT4(Don't Show Units)"/>
<v:cp v:nameU="Extensions" v:lbl="Extension Lines" v:type="1" v:format="Both;End only;Begin only;Neither"
v:invis="true" v:langID="1033" v:val="VT4(Both)"/>
<v:cp v:nameU="Angle" v:type="2" v:invis="false" v:langID="1033" v:val="VT0(1.5707963267949):37"/>
<v:cp v:nameU="Angle" v:lbl="" v:prompt="" v:type="0" v:format="" v:sortKey="" v:invis="false" v:ask="false"
v:langID="0" v:cal="0" v:val="VT0(1.5707963267949):32"/>
<v:cp v:nameU="Hight" v:lbl="Input" v:prompt="Enter Height" v:type="0" v:langID="1033" v:val="VT4(ft)"/>
<v:cp v:nameU="Class" v:lbl="Units_" v:type="0" v:langID="1033" v:val="VT4(ft)"/>
</v:custProps>
<v:userDefs>
<v:ud v:nameU="AntiScale" v:val="VT0(1):26"/>
<v:ud v:nameU="LUnitsFactor" v:val="VT0(0):19"/>
这是为每个<g>
元素创建一个带有对象的数组的方法。它遍历<g>
元素,然后遍历其组成的<v:cp>
元素,然后遍历那些元素的属性。
<svg>
东西使用名称空间。 jQuery不适用于这种情况。我建议使用其他一些库(例如,检查d3),或考虑名称空间(如果您使用纯JavaScript / DOM,即使用getElementsByTagName(..)
而不是getElementsByTagNameNS(..)
。例如,对于d3,而不是jQuery $("g")
,请使用d3.selectAll("g")
,它将起作用。