찾다
웹 프론트엔드JS 튜토리얼AngularJS를 사용하여 대규모 단일 페이지 애플리케이션(SPA) 개발 - 기술 번역

소개

(SPA) 이런 이름에는 무슨 내용이 들어있나요? 클래식 사인펠드 TV 쇼의 팬이라면 도나 창이라는 이름을 꼭 아실 겁니다. Donna를 만난 Jerry는 사실 중국인이 아니었지만, 침술에 대한 관심 등 중국에 대한 고유한 인상을 이야기하다가 우연히 중국 억양이 있는 단어를 발음했기 때문에 이름을 Chang으로 줄였습니다. Donna는 George의 어머니와 전화 통화를 하고 (공자의 말을 인용하여) 몇 가지 조언을 해주었습니다. George가 Donna를 부모에게 소개했을 때 George의 어머니는 Donna가 중국인이 아니라는 것을 알고 Donna의 제안을 받아들이지 않았습니다.

SPA(Single Page Reference)는 A 싱글을 제공하는 것을 목표로 하는 목적으로 정의됩니다. 데스크톱 애플리케이션에 가까운 원활한 사용자 경험을 제공하는 웹 페이지 애플리케이션 또는 웹 사이트 SPA에서는 단일 페이지가 로드되거나 관련 리소스가 로드될 때 HTML, JavaScript 및 CSS와 같은 모든 필수 코드를 가져옵니다. 요청 시 페이지에 동적으로 로드되고 추가되는 경우가 많습니다. HTML5에 도입된 것과 같은 최신 웹 기술은 애플리케이션에서 서로를 인식할 수 있는 독립적인 논리적 페이지와 페이지를 다시 로드하지 않고도 탐색할 수 있는 기능을 제공합니다. 단일 페이지 애플리케이션과의 상호 작용은 종종 백그라운드에서 웹 서버와 동적으로 상호 작용하도록 설계됩니다.


그러면 어떻게 해야 할까요? 이 기술은 ASP.NET의 마스터 페이지와 비교됩니까? ASP.NET의 마스터 페이지를 사용하면 응용 프로그램에서 페이지에 대한 페이지를 만들 수 있다는 것이 사실입니다. 단일 마스터 페이지는 전체 애플리케이션의 모든 페이지(또는 페이지 그룹)에 적용할 모양과 표준 작업을 정의할 수 있습니다. 그런 다음 사용자가 표시할 콘텐츠에 대해 별도의 페이지를 만들 수 있습니다. 콘텐츠 페이지에 요청하면 마스터 페이지의 레이아웃과 콘텐츠 페이지의 콘텐츠를 함께 혼합하여 출력을 생성합니다.

SPA 및 ASP 구현에 대해 자세히 알아보세요. 즉, SPA는 콘텐츠 페이지를 보유하는 간단한 셸 페이지로 간주할 수 있습니다. SPA의 셸 페이지를 다시 로드할 수 없다는 점만 제외하면 마스터 페이지와 같습니다. 마스터 페이지처럼 각각의 새 페이지 요청에 따라 실행됩니다.


아마도 "Single Page Application"은 Donna Cheng과 같은 불운한 이름일 것입니다. 이 기술은 수백 페이지와 수천 명의 사용자를 포함할 수 있는 기업 규모로 확장해야 하는 웹 애플리케이션을 개발하는 데 적합하지 않다고 생각합니다.

이 글의 목표는 인증, 권한 부여, 세션 상태 및 기타 기능을 포함하여 수천 명의 사용자를 지원할 수 있는 단일 페이지 애플리케이션을 기반으로 수백 페이지의 콘텐츠로 구성된 엔터프라이즈급 애플리케이션을 개발하는 것입니다. .



AngularJS - 개요


이 글의 예시에는 사용자 계정 생성/업데이트, 고객 및 제품 생성/업데이트 등의 기능이 포함되어 있습니다. 또한 사용자는 모든 정보에 대해 쿼리를 수행하고 판매 주문을 생성 및 추적할 수 있습니다. 이러한 기능을 구현하기 위해 본 샘플은 AngularJS를 기반으로 개발되었습니다. AngularJS는 Google 및 AngularJS 커뮤니티의 개발자가 유지 관리하는 오픈 소스 웹 애플리케이션 프레임워크입니다.

AngularJS는 클라이언트 측에서 단일 페이지 애플리케이션을 생성하는 데 HTML, CSS 및 JavaScript만 필요합니다. 그 목표는 개발 및 테스트를 더 쉽게 만들고 MVC 웹 애플리케이션의 성능을 향상시키는 것입니다.


이 라이브러리는 HTML에 포함된 다른 사용자 정의 태그 속성을 읽은 다음 이 사용자 정의 속성의 지침을 따르고 페이지 I/O를 생성된 모듈의 표준 JavaScript 변수와 결합합니다. 이러한 JavaScript 표준 변수의 값은 수동으로 설정하거나 정적 또는 동적 JSON 데이터 소스에서 얻을 수 있습니다.



AngularJS 시작하기 - 쉘 페이지, 모듈 및 경로


가장 먼저 해야 할 일은 AngularJS 프레임워크를 프로젝트에 다운로드하는 것입니다. 이 프레임워크는 http://www.php.cn/에서 얻을 수 있습니다. 기사 MS Visual Studio Web Express 2013 Edition을 사용하여 개발되었으므로 다음 명령을 사용하여 Nuget 패키지에서 AngularJS를 설치했습니다.

Install-Package AngularJS -Version 1.2.21

in Nuget 패키지 관리 콘솔 을 간단하고 유연하게 유지하기 위해 빈 Visual Studio 웹 애플리케이션 프로젝트를 만들고 Microsoft Web API 2 라이브러리를 핵심 참조로 선택했습니다. 이 애플리케이션은 Web API 2 라이브러리를 사용하여 서버를 구현합니다. RESTful API에 대한 부수적 요청.


이제 AngularJS를 사용하여 SPA 애플리케이션을 만들 때 가장 먼저 해야 할 두 가지는 콘텐츠 페이지를 가져오기 위한 쉘 페이지와 라우팅 테이블을 설정하는 것입니다. 처음에는 쉘 페이지에 팀 AngularJS만 필요합니다. 위의

<!DOCTYPE html>
<html lang="en">
<head>
<title>AngularJS Shell Page example</title>
</head>
<body> 
<p>
<ul>
<li><a href="#Customers/AddNewCustomer">Add New Customer</a></li>
<li><a href="#Customers/CustomerInquiry">Show Customers</a></li>
</ul>
</p>
<!-- ng-view directive to tell AngularJS where to inject content pages -->
<p ng-view></p>
<script src="http://ajax.googleapis.com/ajax/libs/angularjs/1.0.7/angular.min.js"></script>
<script src="app.js"></script>
</body>
</html>


콘텐츠 페이지를 렌더링해야 하는 위치를 AngularJS에 알려주는 JavaScript 라이브러리 및 ng-view에 대한 참조입니다. 쉘 페이지 예제에서는 여러 링크가 AngularJS 경로에 매핑됩니다. p 태그의 ng-view 지시문은 현재 경로가 변경될 때마다 포함된 보기도 $를 기반으로 AngularJS의 $route 서비스를 보완하기 위해 선택한 경로의 렌더링된 콘텐츠 페이지를 쉘 페이지에 포함할 수 있는 지시문입니다. 예를 들어 사용자가 "새 고객 추가" 링크를 선택하면 AngularJS는 ng-view가 있는 p에 새 고객을 추가하기 위한 콘텐츠를 렌더링합니다. HTML 조각 .


다음 app.js 파일도 셸 페이지에서 참조됩니다. 이 파일의 JavaScript는 애플리케이션을 위한 AngularJS 모듈을 생성합니다. 또한 애플리케이션에 대한 모든 라우팅 구성이 이 파일에 정의됩니다. AngularJS 모듈은 애플리케이션의 다양한 부분을 캡슐화하는 컨테이너로 생각할 수 있습니다. 대부분의 애플리케이션에는 애플리케이션의 여러 부분을 초기화하고 연결하는 기본 메서드가 있습니다. 반면에 AngularJS 애플리케이션에는 기본 메소드가 없으며 대신 모듈이 애플리케이션의 시작 및 구성 방법을 선언적으로 지정하도록 허용하지만 이 기사의 샘플 애플리케이션에는 애플리케이션의 여러 개별 부분이 있지만 하나의 AngularJS 모듈만 있습니다. (고객, 제품, 주문 및 사용자).

이제 app.js의 주요 목적은 아래와 같이 AngularJS 라우팅을 설정하는 것입니다. AngularJS의 $routeProvider 서비스는 Uri를 패턴과 일치시키는 when() 메서드를 허용합니다. 일치하는 항목이 발견되면 개별 페이지의 HTML 콘텐츠는 다음의 제어를 따릅니다. 관련 콘텐츠 컨트롤러 파일은 컨트롤러 파일과 함께 셸 페이지에 로드됩니다. 컨트롤러 파일은 특정 경로 요청 콘텐츠에 대한 참조를 얻는 단순한 JavaScript 파일입니다.

//Define an angular module for our app
var sampleApp = angular.module(&apos;sampleApp&apos;, []);
//Define Routing for the application
sampleApp.config([&apos;$routeProvider&apos;,
    function($routeProvider) {
        $routeProvider.
            when(&apos;/Customers/AddNewCustomer&apos;, {
                templateUrl: &apos;Customers/AddNewCustomer.html&apos;,
                controller: &apos;AddNewCustomerController&apos;
            }).
            when(&apos;/Customers/CustomerInquiry&apos;, {
                templateUrl: &apos;Customers/CustomerInquiry.html&apos;,
                controller: &apos;CustomerInquiryController&apos;
            }).
            otherwise({
                redirectTo: &apos;/Customers/AddNewCustomer&apos;
            });
}]);


AngularJS 컨트롤러


AngularJS 컨트롤러는 특정 범위에 바인딩된 기본 JavaScript 함수에 지나지 않습니다. 컨트롤러는 뷰에 논리를 추가하는 데 사용됩니다. 보기는 HTML 페이지입니다. 이러한 페이지는 단순한 데이터 표시를 위한 것입니다. 데이터를 이러한 HTML 페이지에 바인딩하기 위해 양방향 데이터 바인딩을 사용합니다. 기본적으로 모델(즉, 데이터)을 데이터와 결합하는 것은 컨트롤러의 책임입니다.

<p ng-controller="customerController">
<input ng-model="FirstName" type="text" style="width: 300px" />
<input ng-model="LastName" type="text" style="width: 300px" />       
<p>
<button class="btn btn-primary btn-large" ng-click="createCustomer()"/>Create</button>



위 AddCustomer 템플릿의 경우 ng-controller 지시문은 모든 데이터 바인딩 및 JavaScript를 실행하는 JavaScript 함수 customerController를 참조합니다. 해당 뷰에 대한 기능을 제공합니다.

function customerController($scope) 
{
    $scope.FirstName = "William";
    $scope.LastName = "Gates"; 

    $scope.createCustomer = function () {          
        var customer = $scope.createCustomerObject();
        customerService.createCustomer(customer, 
                        $scope.createCustomerCompleted, 
                        $scope.createCustomerError);
    }
}


기본 제공 - 확장성 문제


나는 동안 이 기사에 대한 강력한 프로그램을 개발 중이었는데, 단일 페이지 애플리케이션을 적용할 때 첫 번째 확장성 문제 중 두 가지가 명백해졌습니다. 실제로 AngularJS에서는 애플리케이션 시작 시 애플리케이션의 셸 페이지에 있는 모든 JavaScript 파일과 컨트롤러를 도입하고 다운로드해야 하므로 수백 개의 JavaScript 파일이 있을 수 있습니다. 그다지 이상적으로 보이지는 않네요. 내가 직면한 또 다른 문제는 AngularJS의 라우팅 테이블이었습니다. 내가 찾은 모든 예에는 모든 경로가 하드코딩되어 있습니다. 그리고 제가 원하는 것은 라우팅 테이블에 수백 개의 라우팅 기록이 들어있는 솔루션이 아닙니다.

성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
브라우저 너머 : 실제 세계의 JavaScript브라우저 너머 : 실제 세계의 JavaScriptApr 12, 2025 am 12:06 AM

실제 세계에서 JavaScript의 응용 프로그램에는 서버 측 프로그래밍, 모바일 애플리케이션 개발 및 사물 인터넷 제어가 포함됩니다. 1. 서버 측 프로그래밍은 Node.js를 통해 실현되며 동시 요청 처리에 적합합니다. 2. 모바일 애플리케이션 개발은 재교육을 통해 수행되며 크로스 플랫폼 배포를 지원합니다. 3. Johnny-Five 라이브러리를 통한 IoT 장치 제어에 사용되며 하드웨어 상호 작용에 적합합니다.

Next.js (백엔드 통합)로 멀티 테넌트 SAAS 애플리케이션 구축Next.js (백엔드 통합)로 멀티 테넌트 SAAS 애플리케이션 구축Apr 11, 2025 am 08:23 AM

일상적인 기술 도구를 사용하여 기능적 다중 테넌트 SaaS 응용 프로그램 (Edtech 앱)을 구축했으며 동일한 작업을 수행 할 수 있습니다. 먼저, 다중 테넌트 SaaS 응용 프로그램은 무엇입니까? 멀티 테넌트 SAAS 응용 프로그램은 노래에서 여러 고객에게 서비스를 제공 할 수 있습니다.

Next.js (Frontend Integration)를 사용하여 멀티 테넌트 SaaS 응용 프로그램을 구축하는 방법Next.js (Frontend Integration)를 사용하여 멀티 테넌트 SaaS 응용 프로그램을 구축하는 방법Apr 11, 2025 am 08:22 AM

이 기사에서는 Contrim에 의해 확보 된 백엔드와의 프론트 엔드 통합을 보여 주며 Next.js를 사용하여 기능적인 Edtech SaaS 응용 프로그램을 구축합니다. Frontend는 UI 가시성을 제어하기 위해 사용자 권한을 가져오고 API가 역할 기반을 준수하도록합니다.

JavaScript : 웹 언어의 다양성 탐색JavaScript : 웹 언어의 다양성 탐색Apr 11, 2025 am 12:01 AM

JavaScript는 현대 웹 개발의 핵심 언어이며 다양성과 유연성에 널리 사용됩니다. 1) 프론트 엔드 개발 : DOM 운영 및 최신 프레임 워크 (예 : React, Vue.js, Angular)를 통해 동적 웹 페이지 및 단일 페이지 응용 프로그램을 구축합니다. 2) 서버 측 개발 : Node.js는 비 차단 I/O 모델을 사용하여 높은 동시성 및 실시간 응용 프로그램을 처리합니다. 3) 모바일 및 데스크탑 애플리케이션 개발 : 크로스 플랫폼 개발은 개발 효율을 향상시키기 위해 반응 및 전자를 통해 실현됩니다.

JavaScript의 진화 : 현재 동향과 미래 전망JavaScript의 진화 : 현재 동향과 미래 전망Apr 10, 2025 am 09:33 AM

JavaScript의 최신 트렌드에는 Typescript의 Rise, 현대 프레임 워크 및 라이브러리의 인기 및 WebAssembly의 적용이 포함됩니다. 향후 전망은보다 강력한 유형 시스템, 서버 측 JavaScript 개발, 인공 지능 및 기계 학습의 확장, IoT 및 Edge 컴퓨팅의 잠재력을 포함합니다.

Demystifying JavaScript : 그것이하는 일과 중요한 이유Demystifying JavaScript : 그것이하는 일과 중요한 이유Apr 09, 2025 am 12:07 AM

JavaScript는 현대 웹 개발의 초석이며 주요 기능에는 이벤트 중심 프로그래밍, 동적 컨텐츠 생성 및 비동기 프로그래밍이 포함됩니다. 1) 이벤트 중심 프로그래밍을 사용하면 사용자 작업에 따라 웹 페이지가 동적으로 변경 될 수 있습니다. 2) 동적 컨텐츠 생성을 사용하면 조건에 따라 페이지 컨텐츠를 조정할 수 있습니다. 3) 비동기 프로그래밍은 사용자 인터페이스가 차단되지 않도록합니다. JavaScript는 웹 상호 작용, 단일 페이지 응용 프로그램 및 서버 측 개발에 널리 사용되며 사용자 경험 및 크로스 플랫폼 개발의 유연성을 크게 향상시킵니다.

Python 또는 JavaScript가 더 좋습니까?Python 또는 JavaScript가 더 좋습니까?Apr 06, 2025 am 12:14 AM

Python은 데이터 과학 및 기계 학습에 더 적합한 반면 JavaScript는 프론트 엔드 및 풀 스택 개발에 더 적합합니다. 1. Python은 간결한 구문 및 풍부한 라이브러리 생태계로 유명하며 데이터 분석 및 웹 개발에 적합합니다. 2. JavaScript는 프론트 엔드 개발의 핵심입니다. Node.js는 서버 측 프로그래밍을 지원하며 풀 스택 개발에 적합합니다.

JavaScript를 어떻게 설치합니까?JavaScript를 어떻게 설치합니까?Apr 05, 2025 am 12:16 AM

JavaScript는 이미 최신 브라우저에 내장되어 있기 때문에 설치가 필요하지 않습니다. 시작하려면 텍스트 편집기와 브라우저 만 있으면됩니다. 1) 브라우저 환경에서 태그를 통해 HTML 파일을 포함하여 실행하십시오. 2) Node.js 환경에서 Node.js를 다운로드하고 설치 한 후 명령 줄을 통해 JavaScript 파일을 실행하십시오.

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
3 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
3 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
3 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
WWE 2K25 : Myrise에서 모든 것을 잠금 해제하는 방법
3 몇 주 전By尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

Atom Editor Mac 버전 다운로드

Atom Editor Mac 버전 다운로드

가장 인기 있는 오픈 소스 편집기

SecList

SecList

SecLists는 최고의 보안 테스터의 동반자입니다. 보안 평가 시 자주 사용되는 다양한 유형의 목록을 한 곳에 모아 놓은 것입니다. SecLists는 보안 테스터에게 필요할 수 있는 모든 목록을 편리하게 제공하여 보안 테스트를 더욱 효율적이고 생산적으로 만드는 데 도움이 됩니다. 목록 유형에는 사용자 이름, 비밀번호, URL, 퍼징 페이로드, 민감한 데이터 패턴, 웹 셸 등이 포함됩니다. 테스터는 이 저장소를 새로운 테스트 시스템으로 간단히 가져올 수 있으며 필요한 모든 유형의 목록에 액세스할 수 있습니다.

DVWA

DVWA

DVWA(Damn Vulnerable Web App)는 매우 취약한 PHP/MySQL 웹 애플리케이션입니다. 주요 목표는 보안 전문가가 법적 환경에서 자신의 기술과 도구를 테스트하고, 웹 개발자가 웹 응용 프로그램 보안 프로세스를 더 잘 이해할 수 있도록 돕고, 교사/학생이 교실 환경 웹 응용 프로그램에서 가르치고 배울 수 있도록 돕는 것입니다. 보안. DVWA의 목표는 다양한 난이도의 간단하고 간단한 인터페이스를 통해 가장 일반적인 웹 취약점 중 일부를 연습하는 것입니다. 이 소프트웨어는

SublimeText3 Linux 새 버전

SublimeText3 Linux 새 버전

SublimeText3 Linux 최신 버전

에디트플러스 중국어 크랙 버전

에디트플러스 중국어 크랙 버전

작은 크기, 구문 강조, 코드 프롬프트 기능을 지원하지 않음