AngularJS:如何将ng-click绑定到使用embed或object元素插入的SVG图像

Spa*_*nen 10 html javascript svg documentfragment angularjs

我想显示存储在文件中的SVG图像,并将angularJs ng-click功能绑定到图像.

我已经尝试将ng-click绑定放在object/embed元素标记以及包装div标记中,但两者都不起作用.

有谁知道如何做到这一点?

尝试html:

<object ng-click="clickItem()" data="file.svg"></object>

<embed ng-click="clickItem()" src="file.svg/>

<div ng-click="clickItem()">
    <object data="file.svg"></object>
</div>

<div ng-click="clickItem()">
    <embed src="file.svg"/>
</div>
Run Code Online (Sandbox Code Playgroud)

加载后得到的html:

<object ng-click="clickItem()" data="file.svg">
    #document
    xml-stylesheet
    <svg ~svg contents....~></svg>
</object>
Run Code Online (Sandbox Code Playgroud)

并且点击不会在任何列出的案例中注册.

Ada*_*dam 10

您可以在所有现代浏览器中使用SVG作为常规图像(http://caniuse.com/svg-img).

<img ng-click="clickItem()" src="file.svg"/>
Run Code Online (Sandbox Code Playgroud)

看到它在行动:http://jsfiddle.net/YJKnD/

  • 虽然这有效,但是你失去了使用css设置svg样式的能力. (3认同)

Den*_*Luz 3

在我们朋友的帮助下,我成功捕获了点击事件ng-include。看看下面的代码:

 <!doctype html>
 <html lang="en" ng-app="myApp"> 
 <head>
<meta charset="UTF-8">
<title>Document</title>

<script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.2.1/angular.min.js"></script>

<script>
/**
*  Module
*
* Description
*/
var myApp = angular.module('myApp', []);

myApp.directive('clickMe', function(){
    // Runs during compile
    return {
        link: function($scope, element, iAttrs, controller) {

            console.log(element);

            element.bind('click', function(){
                console.log('I\'ve just been clicked!');
            })
        }
    };
});

</script>

</head>


 <body>

  <span ng-include="'circle1.svg'" click-me></span>

 </body>
 </html>
Run Code Online (Sandbox Code Playgroud)