Maison > interface Web > js tutoriel > Comment utiliser SpringMvc+AngularJs

Comment utiliser SpringMvc+AngularJs

php中世界最好的语言
Libérer: 2018-03-06 16:23:53
original
1694 Les gens l'ont consulté

Cette fois, je vais vous montrer comment utiliser SpringMvc+AngularJs et quelles sont les précautions lors de l'utilisation de SpringMvc+AngularJs. Voici des cas pratiques, jetons un coup d'oeil.

Le framework front-end est segmenté et compliqué, et le framework lui-même change chaque jour qui passe. Cependant, il existe encore de nombreux bons frameworks, tels que jQuery, mais la plupart des bibliothèques de classes de jQuery sont relativement compliquées. . AngularJs et jQuery sont tous deux des frameworks front-end. Cet article explique principalement l'intégration d'AngularJs et SpringMvc selon le scénario qui vous convient. Téléchargez-le et jetez-y un œil vous-même, et écrivez le vôtre. compréhension de l’intégration.

Table des matières

1. Pourquoi utiliser AngularJs

2 Intégrer SpringMvc et AngularJs

3. ? L'utilisation d'AngulaJs

AngularJS simplifie le développement d'applications en présentant un niveau d'abstraction plus élevé aux développeurs. Comme pour d’autres techniques d’abstraction, une certaine flexibilité est perdue. En d’autres termes, toutes les applications ne sont pas adaptées à AngularJS. AngularJS se préoccupe principalement de la création d'applications CRUD. Heureusement, au moins 90 % des applications WEB sont des applications CRUD.

2. Intégrez SpringMvc et AngularJs en utilisant la

Structure du projet

Comment utiliser SpringMvc+AngularJsUtilisez JavaConfig pour configurer Spring

Utilisez thymeleaf comme un modèle Au lieu de JSP

utilisez

BootStrap

utilisez AngularJs

utilisez JavaConfig pour configurer Spring

Comment utiliser SpringMvc+AngularJs

Cette classe de configuration est utilisée pour remplacer le fichier web.xml, principalement pour enregistrer l'écouteur. La configuration associée du Web
public class AppInitializer implements WebApplicationInitializer { 
        public void onStartup(ServletContext servletContext) throws ServletException {    
        AnnotationConfigWebApplicationContext rootContext = new AnnotationConfigWebApplicationContext();
        rootContext.register(AppConfig.class);
        servletContext.addListener(new ContextLoaderListener(rootContext));
        AnnotationConfigWebApplicationContext dispatcherContext = new AnnotationConfigWebApplicationContext();
        dispatcherContext.register(WebMvcConfig.class);        
 ServletRegistration.Dynamic dispatcher = servletContext.addServlet("dispatcher", new DispatcherServlet(dispatcherContext));
        dispatcher.setLoadOnStartup(1);
        dispatcher.addMapping("/");
    } 
}
Copier après la connexion

comprend deux classes : AppConfig et WebMvcConfig

.

hérite de WebMvcConfigurerAdapter
@Configuration@EnableWebMvc@ComponentScan(basePackages = "com.xvitcoder.springmvcangularjs")@Import({ThymeleafConfig.class})public class WebMvcConfig extends WebMvcConfigurerAdapter {    @Override
    public void configureDefaultServletHandling(DefaultServletHandlerConfigurer configurer) {
        configurer.enable();
    }    @Override
    public void addResourceHandlers(final ResourceHandlerRegistry registry) {
        registry.addResourceHandler("/resources/**").addResourceLocations("/resources/");
    }    @Override
    public void configureMessageConverters(List<HttpMessageConverter<?>> converters) {
        converters.add(new MappingJackson2HttpMessageConverter());        super.configureMessageConverters(converters);
    }
}
Copier après la connexion

réécrit trois méthodes, configurant respectivement le gestionnaire, l'interception des ressources et le convertisseur

Configurez le modèle Thymeleaf ici
@Configurationpublic class ThymeleafConfig {    @Bean
    public ServletContextTemplateResolver templateResolver() {
        ServletContextTemplateResolver resolver = new ServletContextTemplateResolver();
        resolver.setPrefix("/WEB-INF/html/");
        resolver.setSuffix(".html");
        resolver.setTemplateMode("HTML5");
        resolver.setCacheable(false);        return resolver;
    }    @Bean
    public SpringTemplateEngine templateEngine() {
        SpringTemplateEngine engine = new SpringTemplateEngine();
        engine.setTemplateResolver(templateResolver());        return engine;
    }    @Bean
    public ThymeleafViewResolver thymeleafViewResolver() {
        ThymeleafViewResolver resolver = new ThymeleafViewResolver();
        resolver.setTemplateEngine(templateEngine());        return resolver;
    }
}
Copier après la connexion

Utilisation d'AngularJs

Structure du projet

Comment utiliser SpringMvc+AngularJs Concentrons-nous sur l'explication des choses ici. Dans IndexController, la page passera à la page index.html par défaut. :

De nombreux fichiers js sont présentés ici
<!doctype html><html lang="en" ng-app="AngularSpringApp"><head>
    <meta charset="utf-8"/>
    <title>Service App</title>
    <link rel="stylesheet" href="resources/css/app.css"/>
    <link rel="stylesheet" href="resources/bootstrap/css/bootstrap.min.css" /></head><body><div id="wrapper">
    <ul class="menu">
        <li><a href="#/cars">Cars</a></li>
        <li><a href="#/trains">Trains</a></li>
        <li><a href="#/railwaystations">Railway Station</a></li>
    </ul>
    <hr class="" />
    <div ng-view=""></div></div><script src="resources/js/lib/angular/angular.js"></script><script src="resources/js/app.js"></script><script src="resources/js/services.js"></script><script src="resources/js/controllers/RailwayStationController.js"></script><script src="resources/js/controllers/CarController.js"></script><script src="resources/js/controllers/TrainController.js"></script><script src="resources/js/filters.js"></script><script src="resources/js/directives.js"></script></body>
Copier après la connexion

Remarque

Il s'agit du processus d'exécution d'AngularJs : à partir de index.html Commencez par rechercher le fichier app.js et recherchez le fichier contrôleur.js correspondant en fonction du chemin dans le fichier app.js. Le fichier contrôleur.js obtiendra les données de l'arrière-plan et les renverra à la page html correspondante. pour l'affichage

Le module est angulaireJs Concept très important

Trouver le contrôleur et le modèle correspondant selon le chemin
var AngularSpringApp = {};
var App = angular.module(&#39;AngularSpringApp&#39;, [&#39;AngularSpringApp.filters&#39;, &#39;AngularSpringApp.services&#39;, &#39;AngularSpringApp.directives&#39;]);// Declare app level module which depends on filters, and servicesApp.config([&#39;$routeProvider&#39;, function ($routeProvider) {
    $routeProvider.when(&#39;/cars&#39;, {        templateUrl: &#39;cars/layout&#39;,        controller: CarController
    });
    $routeProvider.when(&#39;/trains&#39;, {        templateUrl: &#39;trains/layout&#39;,        controller: TrainController
    });  
    $routeProvider.when(&#39;/railwaystations&#39;, {        templateUrl: &#39;railwaystations/layout&#39;,        controller: RailwayStationController
    });
    $routeProvider.otherwise({redirectTo: &#39;/cars&#39;});
}]);
Copier après la connexion

Utiliser le service $http pour envoyer une requête ajax en arrière-plan pour obtenir des données
var CarController = function($scope, $http) {
    $scope.fetchCarsList = function() {
        $http.get(&#39;cars/carlist.json&#39;).success(function(carList){
            $scope.cars = carList;
        });
    };
    $scope.addNewCar = function(newCar) {
        $http.post(&#39;cars/addCar/&#39; + newCar).success(function() {
            $scope.fetchCarsList();
        });
        $scope.carName = &#39;&#39;;
    };
    $scope.removeCar = function(car) {
        $http.delete(&#39;cars/removeCar/&#39; + car).success(function() {
            $scope.fetchCarsList();
        });
    };
    $scope.removeAllCars = function() {
        $http.delete(&#39;cars/removeAllCars&#39;).success(function() {
            $scope.fetchCarsList();
        });
    };
    $scope.fetchCarsList();
};
Copier après la connexion

Utilisez les balises correspondantes pour recevoir des données et contrôler l'affichage et d'autres opérations
<div class="input-append">
    <input style="width:358px; margin-left: 100px;" class="span2" type="text" ng-model="carName" required="required" min="1" />
    <button class="btn btn-primary" ng-disabled="!carName" ng-click="addNewCar(carName)">Add Car</button></div><h3 style="margin-left:100px;">Car List</h3><div class="alert alert-info" style="width:400px;margin-left:100px;" ng-show="cars.length == 0">
    No cars found</div><table class="table table-bordered table-striped" style="width:450px; margin-left: 100px;" ng-show="cars.length > 0">
    <thead>
        <tr>
            <th style="text-align: center; width: 25px;">Action</th>
            <th style="text-align: center;">Car Name</th>
        </tr>
    </thead>
    <tbody>
        <tr ng-repeat="car in cars">
            <td  style="width:70px;text-align:center;"><button class="btn btn-mini btn-danger" ng-click="removeCar(car)">Remove</button></td>
            <td>{{car}}</td>
        </tr>
    </tbody></table><button style="margin-left:100px;" class="btn btn-danger"  ng-show="cars.length > 1" ng-click="removeAllCars()">Remove All Cars</button>
Copier après la connexion

Comment utiliser SpringMvc+AngularJsRésumé

3. 🎜>L'interface est un peu simple, mais elle ne peut pas cacher le genre de problèmes apportés par AngularJs Fonctionnement pratique et rapide, nous n'avons pas besoin de prêter trop d'attention aux

Opérations DOM

Cette idée. L'introduction du backend depuis le front-end est également une innovation. Pour l'instant, je n'en connais que peu et je ne sais pas comment utiliser de nombreux concepts et usages. Cet article est une bonne introduction à AngularJs.

Je pense que vous maîtrisez les méthodes après avoir lu ces cas. Pour des informations plus intéressantes, veuillez prêter attention aux autres articles connexes sur le site Web chinois de php !

Lecture connexe :
Comment convertir des données de tableau au format HTML au format Json


Définition de plusieurs attributs de classe en HTML Invalid

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal