weixin_33736048 2014-10-13 11:59 采纳率: 0%
浏览 49

$ .ajax在angularjs中不起作用

I am trying to log my client-sided error on on the server side in my angular app. To do this, I am using stacktrace.js and I am using the following factory:

myApp.factory(
"exceptionLoggingService",
["$log","$window", "traceService",
function($log, $window, traceService){
    function error(exception, cause){

        $log.error.apply($log, arguments);

        try{
            var errorMessage = exception.toString();

            var stackTrace = traceService.print({e: exception});

            $.ajax({
                type: "POST",
                url: "/logger", 
                contentType: "application/json",
                data: angular.toJson({
                    url: $window.location.href,
                    message: errorMessage,
                    type: "exception",
                    stackTrace: stackTrace,
                    cause: ( cause || "")
                })
            });
        } catch (loggingError){
            $log.warn("Error server-side logging failed");
            $log.log(loggingError);
        }
    }
    return(error);
}]

);

My problem here, is that I am not using jQuery in my app and I'd like to avoid it as much as possible. as a result when running this code, I get the expected error:

ReferenceError: $ is not defined

How can I make an ajax request without using the $http service here (to avoir circular references in the case)?

  • 写回答

1条回答 默认 最新

  • ~Onlooker 2014-10-13 12:13
    关注

    Please update $.ajax to $http call see code below

    myApp.factory(
        "exceptionLoggingService", ["$log", "$window", "$http", "traceService",
          function($log, $window, $http, traceService) {
            function error(exception, cause) {
    
              $log.error.apply($log, arguments);
    
              try {
                var errorMessage = exception.toString();
    
                var stackTrace = traceService.print({
                  e: exception
                });
                var data = angular.toJson({
                  url: $window.location.href,
                  message: errorMessage,
                  type: "exception",
                  stackTrace: stackTrace,
                  cause: (cause || "")
                })
    
                $http.post("/logger", data).then(
                  function(response) {
                    alert("post sucess")
                  },
                  function(response) {
                    alert("post error")
                  },
                )
    
              } catch (loggingError) {
                $log.warn("Error server-side logging failed");
                $log.log(loggingError);
              }
            }
            return (error);
          }
        ]

    </div>
    
    评论

报告相同问题?

悬赏问题

  • ¥15 2020长安杯与连接网探
  • ¥15 关于#matlab#的问题:在模糊控制器中选出线路信息,在simulink中根据线路信息生成速度时间目标曲线(初速度为20m/s,15秒后减为0的速度时间图像)我想问线路信息是什么
  • ¥15 banner广告展示设置多少时间不怎么会消耗用户价值
  • ¥16 mybatis的代理对象无法通过@Autowired装填
  • ¥15 可见光定位matlab仿真
  • ¥15 arduino 四自由度机械臂
  • ¥15 wordpress 产品图片 GIF 没法显示
  • ¥15 求三国群英传pl国战时间的修改方法
  • ¥15 matlab代码代写,需写出详细代码,代价私
  • ¥15 ROS系统搭建请教(跨境电商用途)