AngularJS -SitePoint로 타이핑 위젯 생성
AngularJS 프로젝트를 시작하는 경우 모든 구성 요소를 각도로 작성할 수 있습니다. 기존 jQuery 플러그인을 재사용하는 것은 확실히 가능하지만, 지침 안에 많은 jQuery를 던지는 것이 항상 올바른 방법은 아닙니다. 저의 조언은 먼저 더 간단하고 더 나은 방식으로 순수한 각도로 동일한 것을 구현할 수 있는지 확인하는 것입니다. 이렇게하면 응용 프로그램 코드를 깨끗하고 유지 관리 할 수 있습니다. 초보자를 대상으로하는이 튜토리얼은 AngularJS가있는 간단한 유형의 위젯을 만들기 위해 독자들을 안내합니다.
개요
이 튜토리얼에서는 누군가가 텍스트 상자에 입력하기 시작하자마자 제안을 생성하는 간단한 유형의 헤드 위젯을 만들 것입니다. 최종 제품이 매우 구성 가능하고 기존 시스템에 쉽게 연결할 수 있도록 앱을 구조적으로 설계 할 것입니다. 창조 과정과 관련된 기본 단계는 다음과 같습니다.
<span>var typeAhead = angular.module('app', []);
</span>
typeAhead<span>.factory('dataFactory', function($http) {
</span> <span>return {
</span> <span>get: function(url) {
</span> <span>return $http.get(url).then(function(resp) {
</span> <span>return resp.data; // success callback returns this
</span> <span>});
</span> <span>}
</span> <span>};
</span><span>});</span>
typeAhead<span>.controller('TypeAheadController', function($scope<span>, dataFactory</span>) { // DI in action
</span> dataFactory<span>.get('states.json').then(function(data) {
</span> $scope<span>.items = data;
</span> <span>});
</span> $scope<span>.name = ''; // This will hold the selected item
</span> $scope<span>.onItemSelected = function() { // this gets executed when an item is selected
</span> <span>console.log('selected=' + $scope.name);
</span> <span>};
</span><span>});</span>
typeAhead<span>.directive('typeahead', function($timeout) {
</span> <span>return {
</span> <span>restrict: 'AEC',
</span> <span>scope: {
</span> <span>items: '=',
</span> <span>prompt: '@',
</span> <span>title: '@',
</span> <span>subtitle: '@',
</span> <span>model: '=',
</span> <span>onSelect: '&'
</span> <span>},
</span> <span>link: function(scope<span>, elem, attrs</span>) {
</span> <span>},
</span> <span>templateUrl: 'templates/templateurl.html'
</span> <span>};
</span><span>});</span>
<:> OnSelect : 메소드 바인딩, 선택이 끝나면 컨트롤러 범위에서 함수를 실행하는 데 사용됩니다.
참고 : 예제 JSON 응답은 다음과 같습니다.
<span>var typeAhead = angular.module('app', []);
</span>
typeAhead<span>.factory('dataFactory', function($http) {
</span> <span>return {
</span> <span>get: function(url) {
</span> <span>return $http.get(url).then(function(resp) {
</span> <span>return resp.data; // success callback returns this
</span> <span>});
</span> <span>}
</span> <span>};
</span><span>});</span>
먼저 사용자가 입력 할 입력 텍스트 필드를 렌더링합니다. 스코프 속성 프롬프트는 자리 표시 자 속성에 할당됩니다. 다음으로, 우리는 상태 목록을 반복하고 이름 및 약어 속성을 표시합니다. 이 속성 이름은 제목 및 자막 범위 속성을 통해 구성됩니다. 지침 NG-M-MouseEnter 및 NG 클래스는 사용자가 마우스로 호버링 할 때 항목을 강조하는 데 사용됩니다. 다음으로, 우리는 필터 : 모델을 사용합니다.이 모델은 입력 필드에 입력 된 텍스트별로 목록을 필터링합니다. 마지막으로, 우리는 입력 텍스트 필드가 비어 있거나 사용자가 항목을 선택했을 때 NG-Hide 지시문을 사용하여 목록을 숨겼습니다. 선택한 속성은 핸들 사이드 () 함수 내부에서 true로 설정되었으며 누군가 입력 필드에 입력을 시작할 때 false false (제안 목록을 표시하기 위해)로 설정됩니다.
4 단계 : 링크 함수를 업데이트하십시오
다음으로 아래와 같이 지시문의 링크 기능을 업데이트하겠습니다.
함수 handleSelection ()은 선택한 상태 이름으로 범위 속성, 모델을 업데이트합니다. 그런 다음 현재 및 선택된 속성을 재설정합니다. 다음으로 onselect () 함수를 호출합니다. 할당 스코프 .model = selectedItem이 바운드 컨트롤러 스코프 속성을 즉시 업데이트하지 않기 때문에 지연이 추가됩니다. 모델이 선택한 항목으로 업데이트 된 후 컨트롤러 스코프 콜백 함수를 실행하는 것이 바람직합니다. 이것이 우리가 $ 타임 아웃 서비스를 사용한 이유입니다.
또한, 함수 iscurrent () 및 setCurrent ()는 템플릿에서 함께 사용하여 자동 완전 제안의 항목을 강조합니다. 다음 CSS는 하이라이트 프로세스를 완료하는 데 사용됩니다.
typeAhead<span>.controller('TypeAheadController', function($scope<span>, dataFactory</span>) { // DI in action
</span> dataFactory<span>.get('states.json').then(function(data) {
</span> $scope<span>.items = data;
</span> <span>});
</span> $scope<span>.name = ''; // This will hold the selected item
</span> $scope<span>.onItemSelected = function() { // this gets executed when an item is selected
</span> <span>console.log('selected=' + $scope.name);
</span> <span>};
</span><span>});</span>
결론 typeAhead<span>.directive('typeahead', function($timeout) {
</span> <span>return {
</span> <span>restrict: 'AEC',
</span> <span>scope: {
</span> <span>items: '=',
</span> <span>prompt: '@',
</span> <span>title: '@',
</span> <span>subtitle: '@',
</span> <span>model: '=',
</span> <span>onSelect: '&'
</span> <span>},
</span> <span>link: function(scope<span>, elem, attrs</span>) {
</span> <span>},
</span> <span>templateUrl: 'templates/templateurl.html'
</span> <span>};
</span><span>});</span>
CSS를 사용하여 Typehead 드롭 다운의 모양을 사용자 정의 할 수 있습니다. 클래스 .dropdown-menu를 사용하여 드롭 다운 메뉴를 타겟팅 할 수 있습니다. 예를 들어, 배경색과 글꼴 색상을 변경하려면 다음 CSS 코드를 사용할 수 있습니다. .Dropdown-menu {<span><span><span><input</span> type<span>="text"</span> ng-model<span>="model"</span> placeholder<span>="{{prompt}}"</span> ng-keydown<span>="selected=false"</span> /></span>
</span><span><span><span><br</span>/></span>
</span>
<span><span><span><div</span> class<span>="items"</span> ng-hide<span>="!model.length || selected"</span>></span>
</span> <span><span><span><div</span> class<span>="item"</span> ng-repeat<span>="item in items | filter:model track by $index"</span> ng-click<span>="handleSelection(item[title])"</span> <span>style<span>="<span>cursor:pointer</span>"</span></span> ng-class<span>="{active:isCurrent($index)}"</span> ng-mouseenter<span>="setCurrent($index)"</span>></span>
</span> <span><span><span><p</span> class<span>="title"</span>></span>{{item[title]}}<span><span></p</span>></span>
</span> <span><span><span><p</span> class<span>="subtitle"</span>></span>{{item[subtitle]}}<span><span></p</span>></span>
</span> <span><span><span></div</span>></span>
</span><span><span><span></div</span>></span></span>
색상 : #. 343a40; 주 CSS 파일 또는 html 파일의
$ scope.onselect = function (item, model, label) {
// 선택한 항목 };
어떻게 할 수 있습니까? Angularjs에서 bootstrap과 함께 typeahead를 사용하십시오.
angularjs에 bootstrap과 함께 Typeahead를 사용하려면 AngularJS 응용 프로그램에 ui.bootstrap 모듈을 포함시켜야합니다. 이 모듈은 Bootstrap의 마크 업 및 CSS를 기반으로 한 AngularJS 지침 세트를 제공합니다. TypeAhead 지시문은 다음과 같이 사용할 수 있습니다.
이 예에서는 상태가 상태 배열, $ viewValue는 사용자가 입력 한 값이며 Limitto : 8 제안 수를 8로 제한합니다. Angularjs?
angularjs의 원격 데이터와 함께 Typeahead를 사용하려면 $ http 서비스를 사용하여 원격 서버에서 데이터를 가져올 수 있습니다. TypeAhead 속성을 사용하여 입력 필드를 페치 된 데이터에 바인딩 할 수 있습니다. 예를 들면 :
$ scope.getStates = function (val) {
return $ http.get ( '/api/states', { params : { 이름 : val
}
return response.data.map (function (item) { return item.name; });
}); };
html에서 getstates 함수를 사용할 수 있습니다. getStates ($ viewValue) "... />
이 예에서는 GetStates가 사용자. <..>
위 내용은 AngularJS -SitePoint로 타이핑 위젯 생성의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

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

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

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

Python은 부드러운 학습 곡선과 간결한 구문으로 초보자에게 더 적합합니다. JavaScript는 가파른 학습 곡선과 유연한 구문으로 프론트 엔드 개발에 적합합니다. 1. Python Syntax는 직관적이며 데이터 과학 및 백엔드 개발에 적합합니다. 2. JavaScript는 유연하며 프론트 엔드 및 서버 측 프로그래밍에서 널리 사용됩니다.

웹 개발에서 JavaScript의 주요 용도에는 클라이언트 상호 작용, 양식 검증 및 비동기 통신이 포함됩니다. 1) DOM 운영을 통한 동적 컨텐츠 업데이트 및 사용자 상호 작용; 2) 사용자가 사용자 경험을 향상시키기 위해 데이터를 제출하기 전에 클라이언트 확인이 수행됩니다. 3) 서버와의 진실한 통신은 Ajax 기술을 통해 달성됩니다.

실제 세계에서 JavaScript의 응용 프로그램에는 프론트 엔드 및 백엔드 개발이 포함됩니다. 1) DOM 운영 및 이벤트 처리와 관련된 TODO 목록 응용 프로그램을 구축하여 프론트 엔드 애플리케이션을 표시합니다. 2) Node.js를 통해 RESTFULAPI를 구축하고 Express를 통해 백엔드 응용 프로그램을 시연하십시오.

보다 효율적인 코드를 작성하고 성능 병목 현상 및 최적화 전략을 이해하는 데 도움이되기 때문에 JavaScript 엔진이 내부적으로 작동하는 방식을 이해하는 것은 개발자에게 중요합니다. 1) 엔진의 워크 플로에는 구문 분석, 컴파일 및 실행; 2) 실행 프로세스 중에 엔진은 인라인 캐시 및 숨겨진 클래스와 같은 동적 최적화를 수행합니다. 3) 모범 사례에는 글로벌 변수를 피하고 루프 최적화, Const 및 Lets 사용 및 과도한 폐쇄 사용을 피하는 것이 포함됩니다.

Python과 JavaScript는 커뮤니티, 라이브러리 및 리소스 측면에서 고유 한 장점과 단점이 있습니다. 1) Python 커뮤니티는 친절하고 초보자에게 적합하지만 프론트 엔드 개발 리소스는 JavaScript만큼 풍부하지 않습니다. 2) Python은 데이터 과학 및 기계 학습 라이브러리에서 강력하며 JavaScript는 프론트 엔드 개발 라이브러리 및 프레임 워크에서 더 좋습니다. 3) 둘 다 풍부한 학습 리소스를 가지고 있지만 Python은 공식 문서로 시작하는 데 적합하지만 JavaScript는 MDNWebDocs에서 더 좋습니다. 선택은 프로젝트 요구와 개인적인 이익을 기반으로해야합니다.

개발 환경에서 Python과 JavaScript의 선택이 모두 중요합니다. 1) Python의 개발 환경에는 Pycharm, Jupyternotebook 및 Anaconda가 포함되어 있으며 데이터 과학 및 빠른 프로토 타이핑에 적합합니다. 2) JavaScript의 개발 환경에는 Node.js, VScode 및 Webpack이 포함되어 있으며 프론트 엔드 및 백엔드 개발에 적합합니다. 프로젝트 요구에 따라 올바른 도구를 선택하면 개발 효율성과 프로젝트 성공률이 향상 될 수 있습니다.

C와 C는 주로 통역사와 JIT 컴파일러를 구현하는 데 사용되는 JavaScript 엔진에서 중요한 역할을합니다. 1) C는 JavaScript 소스 코드를 구문 분석하고 추상 구문 트리를 생성하는 데 사용됩니다. 2) C는 바이트 코드 생성 및 실행을 담당합니다. 3) C는 JIT 컴파일러를 구현하고 런타임에 핫스팟 코드를 최적화하고 컴파일하며 JavaScript의 실행 효율을 크게 향상시킵니다.

JavaScript는 웹 사이트, 모바일 응용 프로그램, 데스크탑 응용 프로그램 및 서버 측 프로그래밍에서 널리 사용됩니다. 1) 웹 사이트 개발에서 JavaScript는 HTML 및 CSS와 함께 DOM을 운영하여 동적 효과를 달성하고 jQuery 및 React와 같은 프레임 워크를 지원합니다. 2) 반응 및 이온 성을 통해 JavaScript는 크로스 플랫폼 모바일 애플리케이션을 개발하는 데 사용됩니다. 3) 전자 프레임 워크를 사용하면 JavaScript가 데스크탑 애플리케이션을 구축 할 수 있습니다. 4) node.js는 JavaScript가 서버 측에서 실행되도록하고 동시 요청이 높은 높은 요청을 지원합니다.
