从KityFomulator开发过程中的SVG小结(包括IE兼容性)

简述

本次的项目是一个公式编辑器.主要使用了Mathjax技术以及kityFomular插件.所谓的kityFomular插件其实本质上是自己封装的用svg绘制可编辑公式的一个第三方库.

调用
创建并发送消息
发送消息
主程序
NBFomulatarEditor
kityFomular核心SVG库

本文将阐述SVG常见坑解决方案与一些css样式常见问题的解决方案(也许会更新).本文针对的IE版本为IE11(调试模式下显示edge浏览器)

IE下的SVG高度继承

在使用SVG的viewBox时.非IE浏览器可以不设置中间层级的高度而自动继承(方便阅读,使用内联样式)

<span class="general_char_view _input_text_item _input_item" style="display:inline-block; width: 49.8274px; height: 39.36px;">
	<div class="nb-formala-wrapper" style="display: block">
    	<div class="nb-formala-editor-panel _nb-formala-editor-panel">
         	<div class="kf-editor-edit-area">
         		<div class="kf-editor-canvas-container">
         			<svg id="kity_svg_0" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" version="1.1" width="100%" height="100%" font-size="50" viewBox="5.456968088664825e-14 -19.68000030517578 49.827449798583984 39.36000061035156">
						<!-- ...SVG内部内容略 -->
					</svg>
        		</div>
        	</div>
        </div>
     </div>
</span>

可以看到,[svg]Dom是[._input_item]的第四代孙子级(非直接子级).
SVG在非IE浏览器中(chrome与safari等),会自动继承祖父级别高度.而在IE浏览器中,SVG只会显式继承直接父级的高度.
相似的问题解决方案可以参见 带有viewBox和width的SVG在IE中没有正确缩放高度.
为了解决这个问题,需要在中间层级全部加上height:100%的显示样式如下

<span class="general_char_view _input_text_item _input_item" style="display:inline-block; width: 49.8274px; height: 39.36px;">
	<div class="nb-formala-wrapper" style="display: block; height:100%">
    	<div class="nb-formala-editor-panel _nb-formala-editor-panel" style="height:100%">
         	<div class="kf-editor-edit-area" style="height:100%">
         		<div class="kf-editor-canvas-container" style="height:100%">
         			<svg id="kity_svg_0" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" version="1.1" width="100%" height="100%" font-size="50" viewBox="5.456968088664825e-14 -19.68000030517578 49.827449798583984 39.36000061035156">
						<!-- ...SVG内部内容略 -->
					</svg>
        		</div>
        	</div>
        </div>
     </div>
</span>
SVG更改viewBox属性

1.问题表述:有的时候想要更改svg的viewBox属性,使用原生的dom.setAttribute(‘viewBox’, newAttr)方法,发现设置的值变成了小写的viewbox,即是没有办法设置成功,如下

<button id="changeSVG" onclick="clickHandler()">更改viewBox</button>
<div style="width: 300px; height: 200px;">
  <svg id="kity_svg_0" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink"
    version="1.1" width="100%" height="100%" font-size="50">
    <!-- ...SVG内部内容 -->
    <rect width="300" height="200"
      style="fill:rgb(187, 255, 0);stroke-width:1;
      stroke:rgb(0,0,0)"/>
  </svg>
</div>
<script>
  function clickHandler(){
    var dom = document.getElementById('kity_svg_0');
    dom.setAttribute('viewBox', '0 0 200 100');
  }
</script>

解决方案:尝试使用setAttributeNS,用指定命名空间赋值

<button id="changeSVG" onclick="clickHandler()">更改viewBox</button>
<div style="width: 300px; height: 200px;">
  <svg id="kity_svg_0" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink"
    version="1.1" width="100%" height="100%" font-size="50">
    <!-- ...SVG内部内容 -->
    <rect width="300" height="200"
      style="fill:rgb(187, 255, 0);stroke-width:1;
      stroke:rgb(0,0,0)"/>
  </svg>
</div>
<script>
  function clickHandler(){
    var dom = document.getElementById('kity_svg_0');
    svg.setAttributeNS('http://www.w3.org/2000/svg', 'viewBox', `0 0 200 100`);
  }
</script>

2.问题描述:在IE下会出现就算使用了setAttributeNS也无法设置值的情况.
解决方案:尝试将命名空间设置为null或者undefined

svg.setAttributeNS(null, 'viewBox', `0 0 200 100`);
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Kity 是一个基于 SVG 的矢量图形库,帮助你快速在页面上创建和使用矢量元素。 面向对象的接口风格在 Kity 里,所有图形,以及交换的数据,都是以强类型的对象出现的,可以非常方便地使用和拓展它们。 丰富的图形Kity 内置了的图形,包括矩形、圆形、椭圆、多边形、自动曲线、直线、正多边形、星形、饼、环、旋转形等等,还有最强大的 Path 工具,可以绘制任意矢量图形 强大的填充能力Kity 对颜色加强了支持,不仅能随意使用 RGB 或 HSL 进行颜色的配置,还支持调色板的定义和使用。Kity 同时支持渐变和纹理的使用,可以让矢量元素更加生动丰富。 完善的坐标变换能力在 Kity ,对图形进行平移、旋转、缩放等变换是非常简单的。而且,这些变换的综合结果还可以获取,用于图形学的一些计算。 灵活的动画支持Kity 内置了一个灵活的动画引擎,你可以使用该引擎方便灵活地创建和使用动画。动画创建的时间线还可以进一步控制:暂停、停止、循环等。同时提供最底层的动画接口,让你有完全的动画能力。 必不可少的事件处理对于需要创建交互的应用来说,事件是必不可少的。Kity 允许你在图形上绑定各种各样的事件,并且可以帮你精确的计算事件发生的坐标(你还可以指定坐标系)。这个是非常重要的,不是吗? 文本支持Kity 在文本的支持上下了苦工,你可以方便地定位文本和设置文本的样式。你还可以使用路径文本,让一个文本沿着指定的路径排列。 滤镜支持Kity 支持最常用的 SVG 滤镜,而且为您预留了接口,可以快速拓展。 强大的图形学支持这个在图形应用当也是非常重要的。在 Kity ,你可以轻松获取图形在指定坐标系下的区域,支持区域的合并、变换操作。Kity 同时对贝塞尔曲线和路径提供了很多有用的工具,比如切割、求字段、求补间等。 开始使用 要开始使用 kity,你需要先在页面引用 kity.min.js: // 引用本地的 kity 库 [removed][removed] // 使用 git 的 CDN 服务引用 [removed] [removed] 然后,你就可以在任何的元素上创建 kity 的画布: [removed]     var paper = new kity.Paper('kity_paper');     var rect = paper.put(new kity.Rect());     var text = paper.put(new kity.Text());     text.setContent('hello kity!');     text.fill('white');     text.setX(100);     text.setY(200);     rect.setBox(text.getBoundaryBox().expand(-15, -10, 15, 10));     rect.setRadius(5);     rect.fill('blue');[removed] 更详细的使用方法请参考 wiki。 标签:Kity

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值