为什么gridOptions(ng-grid)中的“data”参数总是为空?

时间:2015-10-23 19:50:55

标签: javascript java angularjs spring-mvc

这个命令......即,

@echo off
setlocal

set _progId=MyApkInstaller
set _handler=MyApkInstaller.bat

if not "%1"=="" goto uninstall

:install
echo Installing...
reg add HKCU\Software\Classes\.apk\OpenWithProgIds /v %_progId% /t REG_SZ /f
reg add HKCU\Software\Classes\%_progId%\Shell\Open\Command /ve /t REG_SZ /d "%~dp0%_handler% ""%%1""" /f
goto finish

:uninstall
echo Uninstalling...
reg delete HKCU\Software\Classes\.apk
reg delete HKCU\Software\Classes\%_progId%

:finish
endlocal

...似乎成功检索数据 - 如警报所示......即,

enter image description here

但是,似乎命令 - $http.get('http://localhost:8084/nggridtest/tasks') .success(function (data) { alert(JSON.stringify(data)); $scope.tasks = data; // <=== not working??? }); - 似乎没有将数据分配给我的“$ scope.tasks”变量 - 导致空格...即

enter image description here

我在这里做错了什么?

感谢您的帮助!!

(angularjs newby)

以下是更多信息,如果需要......

app.js

$scope.tasks = data;

app.css

    /* global angular */
    var taskApp = angular.module('taskApp', ['ngGrid']);

    var taskController = taskApp.controller('taskController', function taskController($scope, $http) 
    {
        $http.get('http://localhost:8084/nggridtest/tasks')
            .success(function (data) 
            {
                alert(JSON.stringify(data));
                $scope.tasks = data;
            });

        $scope.gridOptions = {
            data: 'tasks',
            columnDefs: [
                {field: 'taskId', displayName: 'taskId'},
                {field: 'taskName', displayName: 'taskName'},
                {field: 'taskDescription', displayName: 'taskDescription'},
                {field: 'taskStartTime', displayName: 'taskStartTime'},
                {field: 'taskEndTime', displayName: 'taskEndTime'},
                {field: 'taskArchived', displayName: 'taskArchived'}
            ]
        };
    });

的index.jsp

    .gridStyle
    {
        margin: 0;
        width:100em;
        height:50em;
    }

TaskController.java

    <%@ page language="java" contentType="text/html; charset=ISO-8859-1" pageEncoding="ISO-8859-1"%>
    <%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core"%>
    <!doctype html>
    <html ng-app="taskApp">
        <head>
            <meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1">
            <title>Spring MVC, REST, AngularJS testing</title>
            <link rel="stylesheet" type="text/css" href="${pageContext.request.contextPath}/webjars/jquery/2.1.4/jquery.css" media="screen">         
            <link rel="stylesheet" type="text/css" href="${pageContext.request.contextPath}/webjars/ng-grid/2.0.14/ng-grid.css" media="screen"> 
            <link rel="stylesheet" type="text/css" href="${pageContext.request.contextPath}/webjars/bootstrap/3.3.1/css/bootstrap.css" media="screen"> 
            <link rel="stylesheet" type="text/css" href="${pageContext.request.contextPath}/resources/js/app.css" media="screen"/>  
            <script type="text/javascript" src="${pageContext.request.contextPath}/webjars/jquery/2.1.4/jquery.js"></script>
            <script type="text/javascript" src="${pageContext.request.contextPath}/webjars/angularjs/1.4.4/angular.js"></script>    
            <script type="text/javascript" src="${pageContext.request.contextPath}/webjars/ng-grid/2.0.14/ng-grid.js"></script>  
            <script type="text/javascript" src="${pageContext.request.contextPath}/webjars/bootstrap/3.3.1/js/bootstrap.js"></script>        
            <script type="text/javascript" src="${pageContext.request.contextPath}/resources/js/app.js"></script>        
        </head>
        <body>
            <div ng-controller="taskController">
                <div class='panel panel-primary row container-fluid' style="margin: 2em; padding:0;">
                    <div class='panel-heading' style="margin: 0;">
                        <h1 class='panel-title'>Entries</h1>
                    </div>
                    <div class='panel-body' style="padding:0;">  
                        <div class="gridStyle" ng-grid="gridOptions"></div>
                    </div>                          
                </div>                
            </div>
        </body>
    </html>

TaskService.java

    package aaa.bbb.ccc.war;

    import java.util.List;
    import org.apache.logging.log4j.LogManager;

    import org.springframework.web.bind.annotation.RequestMapping;
    import org.springframework.web.bind.annotation.RequestMethod;
    import org.springframework.web.bind.annotation.RestController;
    import org.springframework.web.servlet.config.annotation.EnableWebMvc;

    @RestController
    @EnableWebMvc
    public class TaskController
    {
        private static final org.apache.logging.log4j.Logger LOG = LogManager.getLogger("TaskController");

        TaskService taskmanagerservice = new TaskService();

        @RequestMapping(value = "/tasks", method = RequestMethod.GET, headers = "Accept=application/json")
        public List<Task> getAllTasks()
        {
            List<Task> tasks = null;

            try
            {
                tasks = taskmanagerservice.getAllTasks();
            }
            catch (Exception e)
            {
                LOG.error("____________________________getAllTasks____________________________Exception encountered - e.getMessage=" + e.getMessage(), e);
            }

            return tasks;
        }
    }

DBUtility

    package aaa.bbb.ccc.war;

    import java.sql.Connection;
    import java.sql.ResultSet;
    import java.sql.SQLException;
    import java.sql.Statement;
    import java.util.ArrayList;
    import java.util.List;
    import org.apache.logging.log4j.LogManager;

    public class TaskService
    {
        private static final org.apache.logging.log4j.Logger LOG = LogManager.getLogger("TaskService");

        private Connection connection;

        public TaskService()
        {
            connection = DBUtility.getConnection();
        }

        public List<Task> getAllTasks()
        {
            List<Task> tasks = null;

            try
            {
                tasks = new ArrayList<Task>();
                Statement statement = connection.createStatement();
                ResultSet rs = statement.executeQuery("select * from task_list where task_archived=false");
                while (rs.next())
                {
                    Task task = new Task();
                    task.setTaskId(rs.getInt("task_id"));
                    task.setTaskName(rs.getString("task_name"));
                    task.setTaskDescription(rs.getString("task_description"));
                    task.setTaskPriority(rs.getString("task_priority"));
                    task.setTaskStatus(rs.getString("task_status"));
                    tasks.add(task);
                }
            }
            catch (SQLException e)
            {
                LOG.error("____________________________getAllTasks____________________________Exception encountered - e.getMessage=" + e.getMessage(), e);
            }

            return tasks;
        }
    }

Task.java

    package aaa.bbb.ccc.war;

    import java.io.FileNotFoundException;
    import java.io.IOException;
    import java.io.InputStream;
    import java.sql.Connection;
    import java.sql.DriverManager;
    import java.sql.SQLException;
    import java.util.Properties;
    import org.apache.logging.log4j.LogManager;

    public class DBUtility
    {
        private static final org.apache.logging.log4j.Logger LOG = LogManager.getLogger("DBUtility");
        private static Connection connection = null;

        public static Connection getConnection()
        {
            if (connection != null)
            {
                return connection;
            }
            else
            {
                try
                {
                    Properties prop = new Properties();
                    InputStream inputStream = DBUtility.class.getClassLoader().getResourceAsStream("/config.properties");
                    prop.load(inputStream);
                    String driver = prop.getProperty("driver");
                    String url = prop.getProperty("url");
                    String user = prop.getProperty("user");
                    String password = prop.getProperty("password");
                    Class.forName(driver);
                    connection = DriverManager.getConnection(url, user, password);
                }
                catch (ClassNotFoundException e)
                {
                    LOG.error("____________________________getConnection____________________________ClassNotFoundException", e);
                }
                catch (SQLException e)
                {
                    LOG.error("____________________________getConnection____________________________SQLException", e);
                }
                catch (FileNotFoundException e)
                {
                    LOG.error("____________________________getConnection____________________________FileNotFoundException", e);
                }
                catch (IOException e)
                {
                    LOG.error("____________________________getConnection____________________________IOException", e);
                }

                return connection;
            }
        }
    }

的applicationContext.xml

    package aaa.bbb.ccc.war;

    public class Task
    {
        private int task_id;
        private String task_name;
        private String task_description;
        private String task_priority;
        private String task_status;

        public int getTaskId()
        {
            return task_id;
        }
        public void setTaskId(int taskId)
        {
            this.task_id = taskId;
        }

        public String getTaskName()
        {
            return task_name;
        }
        public void setTaskName(String taskName)
        {
            this.task_name = taskName;
        }

        public String getTaskDescription()
        {
            return task_description;
        }
        public void setTaskDescription(String taskDescription)
        {
            this.task_description = taskDescription;
        }

        public String getTaskPriority()
        {
            return task_priority;
        }
        public void setTaskPriority(String taskPriority)
        {
            this.task_priority = taskPriority;
        }

        public String getTaskStatus()
        {
            return task_status;
        }
        public void setTaskStatus(String taskStatus)
        {
            this.task_status = taskStatus;
        }

        @Override
        public String toString()
        {
            return "Task{" + "task_id=" + task_id + ", task_name=" + task_name + ", task_description=" + task_description + ", task_priority=" + task_priority + ", task_status=" + task_status + '}';
        }
    }

的web.xml

    <?xml version="1.0" encoding="UTF-8"?>
    <beans xmlns="http://www.springframework.org/schema/beans"
           xmlns:mvc="http://www.springframework.org/schema/mvc"
           xmlns:context="http://www.springframework.org/schema/context"
           xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
           xsi:schemaLocation="http://www.springframework.org/schema/beans
                               http://www.springframework.org/schema/beans/spring-beans.xsd
                               http://www.springframework.org/schema/mvc
                               http://www.springframework.org/schema/mvc/spring-mvc.xsd
                               http://www.springframework.org/schema/context
                               http://www.springframework.org/schema/context/spring-context.xsd">
        <context:component-scan base-package="aaa.bbb.ccc.war" />
        <mvc:annotation-driven>
            <mvc:message-converters>
                <bean class="org.springframework.http.converter.StringHttpMessageConverter"/>
                <bean class="org.springframework.http.converter.json.MappingJackson2HttpMessageConverter"/>
            </mvc:message-converters>
        </mvc:annotation-driven>
        <mvc:default-servlet-handler/>
        <bean id="viewResolver" class="org.springframework.web.servlet.view.UrlBasedViewResolver"> 
            <property name="viewClass" value="org.springframework.web.servlet.view.JstlView"/> 
            <property name="prefix" value="/jsp/" /> 
            <property name="suffix" value=".jsp" /> 
        </bean>    
        <mvc:resources mapping="/static/**" location="/static/" />
        <mvc:resources mapping="/webjars/**" location="/webjars/" />
        <mvc:resources mapping="/assets/**" location="/assets/" />
        <mvc:resources mapping="/resources/**" location="/resources/" />    
    </beans>

config.properties

    <web-app xmlns="http://xmlns.jcp.org/xml/ns/javaee"
             xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
             xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_3_1.xsd"
             version="3.1">
        <filter>
            <filter-name>charEncodingFilter</filter-name>
            <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>
            <init-param>
                <param-name>encoding</param-name>
                <param-value>UTF-8</param-value>
            </init-param>
            <init-param>
                <param-name>forceEncoding</param-name>
                <param-value>true</param-value>
            </init-param>
        </filter>
        <filter-mapping>
            <filter-name>charEncodingFilter</filter-name>
            <url-pattern>/*</url-pattern>
        </filter-mapping>
        <listener>
            <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
        </listener>
        <listener>
            <listener-class>org.springframework.web.context.request.RequestContextListener</listener-class>
        </listener>    
        <context-param>
            <param-name>contextConfigLocation</param-name>
            <param-value>
                WEB-INF/spring/applicationContext.xml
            </param-value>
        </context-param>
        <servlet>
            <servlet-name>appServlet</servlet-name>
            <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
            <init-param>
                <param-name>contextConfigLocation</param-name>
                <param-value>
                    WEB-INF/spring/applicationContext.xml           
                </param-value>
            </init-param>
            <load-on-startup>1</load-on-startup>
        </servlet>
        <servlet-mapping>
            <servlet-name>appServlet</servlet-name>
            <url-pattern>/</url-pattern>
        </servlet-mapping>
        <welcome-file-list>
            <welcome-file>index.html</welcome-file>
            <welcome-file>index.htm</welcome-file>
            <welcome-file>index.jsp</welcome-file>
            <welcome-file>default.html</welcome-file>
            <welcome-file>default.htm</welcome-file>
            <welcome-file>default.jsp</welcome-file>
        </welcome-file-list>
    </web-app>

log4j2.xml

    driver=org.apache.derby.jdbc.ClientDriver
    url=jdbc:derby://localhost:1527/taskmanager
    user=app
    password=app

使用了derby数据库

    <?xml version="1.0" encoding="UTF-8"?>
    <Configuration status="warn" name="testLogEvent" packages="">
        <Appenders>
            <Console name="STDOUT" target="SYSTEM_OUT">
               <PatternLayout pattern="%-7p %d [%t] %c %x - %m%n"/>           
           </Console>
            <!-- writes log file to the tomee "logs" folder... -->       
            <File name="appLog" fileName="../logs/nggridtest.log">
                <PatternLayout>
                    <Pattern>%-7p %d [%t] %c %x - %m%n</Pattern>                
                </PatternLayout>
            </File>
            <Async name="Async">
                <AppenderRef ref="appLog"/>
            </Async>
        </Appenders>
        <Loggers>
            <Root level="DEBUG">
                <AppenderRef ref="STDOUT"/>  
                <AppenderRef ref="Async"/>                      
            </Root>
        </Loggers>
    </Configuration>

项目结构

enter image description here

1 个答案:

答案 0 :(得分:0)

正如Lrossy所说,可能是对象尚未定义。所以在你的控制器或链接函数的开头(在获取请求之前),定义它:

$scope.tasks = []

那么,也许它需要轻推应用范围?不太可能,因为$ http知道这样做,但它可能有助于把它放在你的成功处理程序中:

if (!$scope.$$phase) {
  $scope.$apply();
}