Angularjs 如何使用路由在面包屑中添加fonticons

Angularjs 如何使用路由在面包屑中添加fonticons,angularjs,angularjs-directive,angular-ui-router,angular-ui,angular-bootstrap,Angularjs,Angularjs Directive,Angular Ui Router,Angular Ui,Angular Bootstrap,我有一个角度基准仪表板应用程序,在应用程序仪表板页面图标中,当我单击特定图标时,该图标应重定向到带有该图标的菜单面包屑的路由页面。不显示图像,而必须在该部分包含字体图标 displayImg用于显示图像,displayName用于显示名称 下面的代码与图像配合得很好。现在我必须替换为字体图标。 如何做到这一点 这是一个有效的plunker代码: 在示例中,当您单击详细信息时,主图标在菜单中,当您单击产品时,产品图标将在那里,订单意味着订单图标将在那里,其所有图像都在这里的特定路线下提到 .st

我有一个角度基准仪表板应用程序,在应用程序仪表板页面图标中,当我单击特定图标时,该图标应重定向到带有该图标的菜单面包屑的路由页面。不显示图像,而必须在该部分包含字体图标

displayImg用于显示图像,displayName用于显示名称

下面的代码与图像配合得很好。现在我必须替换为字体图标。 如何做到这一点

这是一个有效的plunker代码:

在示例中,当您单击详细信息时,主图标在菜单中,当您单击产品时,产品图标将在那里,订单意味着订单图标将在那里,其所有图像都在这里的特定路线下提到

.state('home.product', {
        url: '/product',
        views: {
            'main@': {
                templateUrl: 'product.html',
            }
        },
        data: {
            displayName: 'product',
            displayImg: ''
        }
    })
      .state('home.order', {
        url: '/order',
        views: {
            'main@': {
                templateUrl: 'order.html',
            }
        },
        data: {
            displayName: 'ordericon',
            displayImg: ''
        }
})
这是用于动态菜单的面包屑库

面包屑js:

/**
 * uiBreadcrumbs automatic breadcrumbs directive for AngularJS & Angular ui-router.
 *
 * https://github.com/michaelbromley/angularUtils/tree/master/src/directives/uiBreadcrumbs
 *
 * Copyright 2014 Michael Bromley <michael@michaelbromley.co.uk>
 */


(function() {

    /**
     * Config
     */
    var moduleName = 'ngBreadCrumb';
    var templateUrl = 'ngBreadCrumbTemplate.html';

    /**
     * Module
     */
    var module;
    try {
        module = angular.module(moduleName);
    } catch(err) {
        // named module does not exist, so create one
        module = angular.module(moduleName, ['ui.router']);
    }

    module.directive('uiBreadcrumbs', ['$interpolate', '$state', function($interpolate, $state) {
            return {
                restrict: 'E',
                templateUrl: function(elem, attrs) {
                    return attrs.templateUrl || templateUrl;
                },
                scope: {
                    displaynameProperty: '@',
                    displayimgProperty:'@',   
                    abstractProxyProperty: '@?'
                },
                link: function(scope) {
                    scope.breadcrumbs = [];
                    if ($state.$current.name !== '') {
                        updateBreadcrumbsArray();
                    }
                    scope.$on('$stateChangeSuccess', function() {
                        updateBreadcrumbsArray();
                    });

                    /**
                     * Start with the current state and traverse up the path to build the
                     * array of breadcrumbs that can be used in an ng-repeat in the template.
                     */
                    function updateBreadcrumbsArray() {
                        var workingState;
                        var displayName;
                        var displayImg = 'http://www.freeiconspng.com/uploads/home-icon-png-home-icon-31.png';  //Sampriya
                        var breadcrumbs = [];
                        var currentState = $state.$current;

                        while(currentState && currentState.name !== '') {
                            workingState = getWorkingState(currentState);
                            if (workingState) {
                                displayName = getDisplayName(workingState);
                                displayImg = getDisplayImg(workingState);//Sampriya

                                if (displayName !== false && !stateAlreadyInBreadcrumbs(workingState, breadcrumbs)) {
                                    if (displayImg !== false) {
                                        breadcrumbs.push({
                                            displayName: displayName,
                                            displayImg: displayImg,
                                            route: workingState.name
                                        });
                                    }
                                    else {
                                        breadcrumbs.push({
                                            displayName: displayName,
                                            route: workingState.name
                                        });
                                    }

                                }
                                //Sampriya
                                //if (displayImg !== false && !stateAlreadyInBreadcrumbs(workingState, breadcrumbs)) {
                                //    breadcrumbs.push({
                                //        displayImg: displayImg,
                                //        route: workingState.name
                                //    });
                                //}
                                //=====
                            }
                            currentState = currentState.parent;                            
                        }
                        breadcrumbs.reverse();
                        scope.breadcrumbs = breadcrumbs;
                    }

                    /**
                     * Get the state to put in the breadcrumbs array, taking into account that if the current state is abstract,
                     * we need to either substitute it with the state named in the `scope.abstractProxyProperty` property, or
                     * set it to `false` which means this breadcrumb level will be skipped entirely.
                     * @param currentState
                     * @returns {*}
                     */
                    function getWorkingState(currentState) {
                        var proxyStateName;
                        var workingState = currentState;
                        if (currentState.abstract === true) {
                            if (typeof scope.abstractProxyProperty !== 'undefined') {
                                proxyStateName = getObjectValue(scope.abstractProxyProperty, currentState);
                                if (proxyStateName) {
                                    workingState = $state.get(proxyStateName);
                                } else {
                                    workingState = false;
                                }
                            } else {
                                workingState = false;
                            }
                        }
                        return workingState;
                    }

                    /**
                     * Resolve the displayName of the specified state. Take the property specified by the `displayname-property`
                     * attribute and look up the corresponding property on the state's config object. The specified string can be interpolated against any resolved
                     * properties on the state config object, by using the usual {{ }} syntax.
                     * @param currentState
                     * @returns {*}
                     */
                    function getDisplayName(currentState) {
                        var interpolationContext;
                        var propertyReference;
                        var displayName;

                        if (!scope.displaynameProperty) {
                            // if the displayname-property attribute was not specified, default to the state's name
                            return currentState.name;
                        }
                        propertyReference = getObjectValue(scope.displaynameProperty, currentState);

                        if (propertyReference === false) {
                            return false;
                        } else if (typeof propertyReference === 'undefined') {
                            return currentState.name;
                        } else {
                            // use the $interpolate service to handle any bindings in the propertyReference string.
                            interpolationContext =  (typeof currentState.locals !== 'undefined') ? currentState.locals.globals : currentState;
                            displayName = $interpolate(propertyReference)(interpolationContext);
                            return displayName;
                        }
                    }
                    //Sampriya
                    /**
                    * Resolve the displayImg of the specified state. Take the property specified by the `displayimg-property`
                    * attribute and look up the corresponding property on the state's config object. The specified string can be interpolated against any resolved
                    * properties on the state config object, by using the usual {{ }} syntax.
                    * @param currentState
                    * @returns {*}
                    */
                    function getDisplayImg(currentState) {
                        var interpolationContext;
                        var propertyReference;
                        var displayImg;                        
                        if (!scope.displayimgProperty) {
                            // if the displayimg-property attribute was not specified, default to the state's name
                            return currentState.name;
                        }
                        propertyReference = getObjectValue(scope.displayimgProperty, currentState);
                        if (propertyReference === false) {
                            return false;
                        } else if (typeof propertyReference === 'undefined') {
                            return currentState.name;
                        } else {
                            // use the $interpolate service to handle any bindings in the propertyReference string.
                            interpolationContext = (typeof currentState.locals !== 'undefined') ? currentState.locals.globals : currentState;
                            displayImg = $interpolate(propertyReference)(interpolationContext);
                            return displayImg;
                        }
                    }
                    //=======

                    /**
                     * Given a string of the type 'object.property.property', traverse the given context (eg the current $state object) and return the
                     * value found at that path.
                     *
                     * @param objectPath
                     * @param context
                     * @returns {*}
                     */
                    function getObjectValue(objectPath, context) {
                        var i;
                        var propertyArray = objectPath.split('.');
                        var propertyReference = context;

                        for (i = 0; i < propertyArray.length; i ++) {
                            if (angular.isDefined(propertyReference[propertyArray[i]])) {
                                propertyReference = propertyReference[propertyArray[i]];
                            } else {
                                // if the specified property was not found, default to the state's name
                                return undefined;
                            }
                        }
                        return propertyReference;
                    }

                    /**
                     * Check whether the current `state` has already appeared in the current breadcrumbs array. This check is necessary
                     * when using abstract states that might specify a proxy that is already there in the breadcrumbs.
                     * @param state
                     * @param breadcrumbs
                     * @returns {boolean}
                     */
                    function stateAlreadyInBreadcrumbs(state, breadcrumbs) {
                        var i;
                        var alreadyUsed = false;
                        for(i = 0; i < breadcrumbs.length; i++) {
                            if (breadcrumbs[i].route === state.name) {
                                alreadyUsed = true;
                            }
                        }
                        return alreadyUsed;
                    }
                }
            };
        }]);
})();
/**
*用于AngularJS和AngularUI路由器的uiBreadcrumbs自动breadcrumbs指令。
*
* https://github.com/michaelbromley/angularUtils/tree/master/src/directives/uiBreadcrumbs
*
*版权所有2014迈克尔·布罗姆利
*/
(功能(){
/**
*配置
*/
变量moduleName='ngBreadCrumb';
var templateUrl='ngBreadCrumbTemplate.html';
/**
*模块
*/
var模块;
试一试{
模块=角度模块(模块名称);
}捕捉(错误){
//命名模块不存在,请创建一个
module=angular.module(moduleName,['ui.router']);
}
module.directive('uiBreadcrumbs',['$interpolate','$state',function($interpolate,$state){
返回{
限制:'E',
templateUrl:函数(元素、属性){
返回attrs.templateUrl | | templateUrl;
},
范围:{
displaynameProperty:“@”,
displayimgProperty:“@”,
abstractProxyProperty:“@?”
},
链接:功能(范围){
scope.breadcrumbs=[];
如果($state.$current.name!=''){
UpdateBroadCrumbsarray();
}
作用域.$on(“$stateChangeSuccess”,函数(){
UpdateBroadCrumbsarray();
});
/**
*从当前状态开始,沿路径向上遍历以构建
*可在模板中的ng重复中使用的面包屑数组。
*/
函数updateBroadCrumbsarray(){
var工作状态;
变量显示名;
var displayImg=http://www.freeiconspng.com/uploads/home-icon-png-home-icon-31.png“;//桑普里亚
var breadcrumbs=[];
var currentState=$state.$current;
while(currentState&¤tState.name!=''){
工作状态=getWorkingState(当前状态);
if(工作状态){
displayName=getDisplayName(工作状态);
displayImg=getDisplayImg(工作状态);//Sampriya
if(displayName!==false&&!stateAlreadyInBreadcrumbs(工作状态,breadcrumbs)){
如果(显示img!==false){
面包屑({
displayName:displayName,
displayImg:displayImg,
路由:workingState.name
});
}
否则{
面包屑({
displayName:displayName,
路由:workingState.name
});
}
}
//桑普里亚
//if(displayImg!==false&&!stateAlreadyInBreadcrumbs(工作状态,breadcrumbs)){
//面包屑({
//displayImg:displayImg,
//路由:workingState.name
//    });
//}
//=====
}
currentState=currentState.parent;
}
面包屑。反向();
scope.breadcrumbs=breadcrumbs;
}
/**
*获取要放入breadcrumbs数组的状态,考虑到如果当前状态是抽象状态,
*我们需要用`scope.abstractProxyProperty`属性中命名的状态替换它,或者
*将其设置为'false',这意味着将完全跳过此面包屑级别。
*@param currentState
*@returns{*}
*/
函数getWorkingState(当前状态){
变量proxyStateName;
var工作状态=当前状态;
if(currentState.abstract==true){
if(typeof scope.abstractProxyProperty!=“未定义”){
proxyStateName=getObjectValue(scope.abstractProxyProperty,currentState);
if(proxyStateName){
workingState=$state.get(proxyStateName);
}否则{
<ol class="breadcrumb">
    <li ng-repeat="crumb in breadcrumbs">
        <!--ng-class="{ active: $last }"--><a ui-sref="{{ crumb.route }}" ng-if="!$last"><img ng-src="{{ crumb.displayImg }}" class="responsiveBCrumb" alt="" />{{crumb.displayName}}</a><span ng-show="$last"><img ng-src="{{ crumb.displayImg }}" class="responsiveBCrumb" alt="" />{{crumb.displayName}}</span>
    </li>
</ol>
<h1>Product</h1>
<div class="note_panel note_panel_yellow">
    <div class="note_body note_panel_solid_border">
        <h4>Product Page</h4>
        <p>Sample Angular Breadcrumb</p>
    </div>
</div>