HTML_CSS/HTML의 데이터 바인딩
信息来源:Wayne_Deng的专栏
有没想过在java script中使用recordset?原来在客户端操作数据也可以这样简单,定义一个数据源,将数据绑定在各种tag上,实现应用程序般的效果,酷毙了!(首先申明一点,文章的内容全部来自msdn,不过用我自己的话总结而已。)
先看看这样两个例子:
http://msdn.microsoft.com/workshop/samples/author/databind/dbevts.htm
http://msdn.microsoft.com/workshop/samples/author/databind/dbupdate.htm
不得不又一次佩服微软。
这个是DataBinding的架构:
当然实现数据绑定有下面几步:
第一步,定义数据源
从IE4.0起,就支持下面四种数据源:
Tabular Data Control (TDC)
TDC提供了一个简单的访问带有格式的文本数据的方法,一般是csv文件。
下面是一个简单的示例:
Remote Data Service (RDS)
远程数据服务,直接访问远程服务器端的数据,Internet Explorer 4.0. RDS 通过OLE-DB 或 Open Database Connectivity (ODBC)来实现。
示例:
不过感觉有点安全性的问题,因为客户端能看到这段代码。
XML Data Source
XML就不多说了,在IE4.0中这样使用:
Internet Explorer 5以上可以这样:
另外IE还提供了一个XML数据岛的概念:XML Data Islands.
MSHTML Data Source
html数据页示例:
Hector
Modest
Moussorgsky
1811
一旦定义可以这样访问:
.第二步:绑定数据到HTML元素上
一般都是通过tag中的datasrc和datafld实现绑定的。例如:
和
这个是绑定表格的示例:
http://msdn.microsoft.com/workshop/samples/author/databind/dbtable.htm
其中数据来源:
绑定的table
First | Last | Birth | Death | Origin |
효과는 다음과 같습니다.
첫 번째 마지막 출생 사망 원인
Berlioz 1803 1869 프랑스
Modest Moussorgsky 1839 1881 러시아
Franz Liszt 1811 1886 프랑스
Antonio Vivaldi 1678 1741 이탈리아
Johann Sebastian Bach 168 5 1750 독일
Ludwig van 베토벤 1770년 1827년 독일
Wolfgang Amadeus Mozart 1756 1791 오스트리아
Joseph Haydn 1732 1809 독일
Claude Debussy 1862 1918 프랑스
세 번째 단계: 데이터의 동적 추가, 삭제 등(객체 모델)
물론 바인딩은 동적일 수 있습니다.
스크립트에서:
span1.dataSrc = "#dsoComposer";
span1.dataFld = "compsr_first";
html은 다음과 같습니다.
그리고 데이터 소스의 ADO에 액세스할 수 있습니다.
var oRecordSet = dsoComposer.recordset; 물론 oRecordSet .MoveNext 등이 있습니다.
예:
onclick="tdcComposers.recordset.MoveFirst()"> 입력 ID=cmdNavPrev TYPE=BUTTON VALUE=" < "
onclick="tdcComposers.recordset.MovePrevious();
if (tdcComposers.recordset.BOF)
tdcComposers.recordset.MoveFirst();" > ;
onclick="tdcComposers.recordset.MoveNext();
if (tdcComposers.recordset.EOF)
tdcComposers .recordset .MoveLast();">
onclick="tdcComposers.recordset.MoveLast()">
다음과 같이 사용할 수도 있습니다.
레코드를 추가하고 삭제하세요: oRecordSet.AddNew() 및 oRecordSet.Delete().
3단계: 다양한 데이터 이벤트에 대응(이벤트 모델)
데이터가 변경된 후 그에 맞게 처리하는 방법은 무엇인가요?
msdn에서 제공하는 메소드는 다음과 같습니다.
>이벤트 이름 목록은 다음과 같습니다.
이벤트 버블 취소 가능 적용 대상 Internet Explorer 버전에 도입
onbeforeupdate True True 바인딩된 요소 4.0
onafterupdate True False 바인딩된 요소 4.0
onrowenter True False D SO 4.0
onrowexit True False DSO 4.0
onbeforeunload False False 창 4.0
ondataavailable True False DSO 4.0
ondatasetcomplete True False DSO 4.0
ondatasetchanged True False DSO 4.0
onerrorupdate True True 바운드 요소 4.0
onreadystatechange True False DSO 4.0
oncellchange True False DSO 5.0
onrowsinserted True False DSO 5.0
onrowsdelete True False DSO 5.0 어떻습니까?
http://msdn.microsoft.com/workshop/samples/author/databind/dbevts.htm은 비교적 포괄적인 응용 프로그램 예라고 생각합니다. 주의 깊게 연구하면 분명히 뭔가를 얻을 수 있을 것입니다.
인터넷에서 페이징을 달성하기 위해 데이터 바인딩을 사용하는 사례는 실제로 많습니다. 사실 데이터 바인딩을 사용하면 더 많은 작업을 수행할 수 있습니다. 리치 클라이언트에는 매우 복잡한 데이터 그리드를 만드는 것과 같은 매우 큰 응용 프로그램이 있어야 합니다.
지금 더 알아보고 싶은 것은 클라이언트의 데이터 바인딩이 서버에 아무런 영향을 주지 않기 때문에 서버와 동기화를 쉽게 달성하는 방법입니다(서버에서 데이터 소스를 생성할 수 있지만 서버에서의 작업은 클라이언트는 자동으로 서버로 돌아가지 않습니다), msdn은 RDS를 사용할 수 있다고 말하지만 이 방법은 너무 서투르고 안전하지 않습니다.

핫 AI 도구

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

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

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

Clothoff.io
AI 옷 제거제

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

인기 기사

뜨거운 도구

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

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

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

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

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

뜨거운 주제











이것은 우리가 양식 접근성에 대해 한 작은 시리즈의 세 번째 게시물입니다. 두 번째 게시물을 놓친 경우 "사용자 초점 관리 : Focus-Visible"을 확인하십시오. ~ 안에

이 튜토리얼은 Smart Forms 프레임 워크를 사용하여 전문적인 JavaScript 양식을 작성하는 것을 보여줍니다 (참고 : 더 이상 사용할 수 없음). 프레임 워크 자체를 사용할 수 없지만 원칙과 기술은 다른 형태의 건축업자와 관련이 있습니다.

CSS Box-Shadow 및 개요 속성은 주제를 얻었습니다. 실제 테마에서 어떻게 작동하는지에 대한 몇 가지 예와 이러한 스타일을 WordPress 블록 및 요소에 적용 해야하는 옵션을 보자.

Svelte Transition API는 맞춤형 전환을 포함하여 문서를 입력하거나 떠날 때 구성 요소를 애니메이션하는 방법을 제공합니다.

웹 사이트의 컨텐츠 프레젠테이션을 설계하는 데 얼마나 많은 시간을 소비합니까? 새 블로그 게시물을 작성하거나 새 페이지를 만들 때

이 기사에서 우리는 스크롤 바의 세계로 뛰어들 것입니다. 너무 화려하게 들리지는 않지만 잘 설계된 페이지가 손을 잡고 있습니다.

NPM 명령은 서버 시작 또는 컴파일 코드와 같은 것들에 대한 일회성 또는 지속적으로 실행되는 프로세스로 다양한 작업을 실행합니다.
