在 HTML 中使用JavaScript
JavaScript能以两种方式嵌入HTML:
- 作为语句和函数使用时,用 SCRIPT 标记
- 作为事件处理程序使用时,用 HTML 标记
SCRIPT 标记
使用SCRIPT标记把脚本嵌入在HTML中,格式如舷:
<script> <BR>_ JavaScript 语句<BR></script>
LANGUAGE属性作为可选项,用于指定脚本语言,用法如下:
是<script>的结束标志,之间可以包括任意多的JavaScript语句.</script>
JavaScript是区分大小写档
例1 一个简单的脚本
That's all, folks.
例1中的页面显示:
Hello net.That's all folks.
代码隐匿
在不识别JavaScript的旧版本浏览器上,可以把脚本放置在注释域中,这样JavaScript代码就不会被显示出来. 把整个脚本用HTML的注释标记括起来:
定义和调用函数
在页(page)被装载后,被置于SCRIPT标记之间的脚本被分析.函数被存贮起来,但并未执行. 函数由页内的事件调用执行.
正确理解定义函数与调用函数之间的区别是很重要的,定义函数仅仅是命名了这个函数和说明当此函数被调用时做什么,而调用函数才利用传来的参数真正执行指定的动作.
例2 一个带有函数和注释的脚本
All done.
例2中的页面显示:
We passed 5 to the function.
The function returned 25.
All done.
HEAD标记
通常,应该在文档的HEAD部分定义页(page)的所有函数,因为HEAD被首先装载,这就保证了用户做任何可能调用函数的动作前,函数已全部装载.
例3 有两个函数的脚本.
<script><BR><!--- hide script from old browsers <BR>function bar() {<BR> document.write("<HR ALIGN='LEFT' WIDTH=25%>")<BR>}<BR>function output(head,level,string) {<BR> document.write("<H" + level + ">" + head + "" + level + "><p>" + string)<BR>}<BR>// end hiding from old browsers --><BR></script>
<script><BR><!--- hide script from old browers<BR>document.write (bar(),output("Make Me Big",3,"Make me ordinary."))<BR>// end hiding from old browsers --><BR></script>
Thanks.
例3的结果:
Make Me Big
Make me ordinary.undefinedundefined
Thanks.
引号
用单引号(')把字符串常量括起来,用双引号把属性的值括起来,这样脚本能够把二者区分开. 在上个例子中, 函数bar中,常量left被放在属性值.再举一个例子:
编写事件处理程序脚本(Scripting Event Handlers)
Navigator上的JavaScript应用程序大部分是事件驱动的,事件常常是用户动作的结果. 例如: 按动按钮是一个事件, 结果是把focus赋与一个form元素.Navigator能够识别一组特定的事件. 你可以定义event handlers脚本,这些脚本在事件发生时会被自动执行.
事件处理程序是作为HTML标记的属性放在文档中的,把要执行JavaScript代码赋给HTML标记. 语法如下:
其中, TAG是HTML的某一标记, eventHandler是事件处理程序的名称.
例如, 假定已创建了一个名为compute的JavaScript函数,你可以把对该函数的调用赋给这个按钮的onClick事件处理程序,从而实现当用户按此按钮时,Navigator执行函数compute.
你可以把任何JavaScript语句放在onClick后的引号内,多个语句之间用分号隔开.这些语句只在当用户按动此按钮时才被执行.
一般说来,把自己的事件处理程序定义成函数是一种好习惯,因为:
- 这使你的代码模块化--- 同一个函数可以作为多个不同item的事件处理程序.
- 这使你的代码容易读懂.
请注意,在此例中,使用this.form来引用当前form, 关键字this用来引用当前对象,此处即指button对象,于是this.form结构被用来引用包含此button的form. 上例中onClick事件处理程序是以this.form(当前form)为参数调用compute()函数.
能用于HTML标记中的事件如下:
- Focus, Blur, Change事件: 文本域,文本区和选择
- Click事件: 按钮,无线按钮,核对框,递交按钮,复位按钮,链接
- Select事件: 文本域,文本区
- MouseOver事件: 链接
如果一事件可用在HTML标记里, 则可以给它定义事件处理程序.通常事件处理程序的名称是以on开头,后跟事件名称. 如, Focus的处理程序名为onFocus.
许多对象有模拟事件的方法(method).如,button有一个名为click的方法能模拟按钮被按下. 注意: 模拟事件的方法不能触发事件处理程序.如方法click并不能触发事件处理程序onClick. 但是,你可以直接调用事件处理程序(如,在脚本中,显式调用onClick).
事件 | 何时发生 | 事件处理程序 |
blur | 用户将input focus从form元素上移去 | onBlur |
click | 用户在form元素或连接上接动鼠标 | onClick |
change | 用户改变了文本,文本区或选择元素的值 | onChange |
focus | 用户把input focus赋给form元素 | onFocus |
load | 用户把页装入Navigato | onLoad |
mouseover | 用户把鼠标光标从link或anchor上移过 | onMouseOve |
select | 用户选择了form元素的输入域 | onSelect |
submit | 用户提交了一个form | onSubmit |
unload | 用户退出此页 | onUnload |
例4 有一个form和一个event handler属性的脚本
例4中的页面显示
技巧与技术
本节介绍几种有用的编写脚本的技术
更新页(Updating Pages)
在Navigator上JavaScript是按从页的顶部到下的顺序生成结果. 一旦有些东西被重新设计(format),你只能靠重新装载此页的办法来改变,目前,你只能更新整 个页, 而不能只更新某一部分. 但是你可以单独更新frame中的"sub-window".
打印
目前, 还不能把用JavaScript产生的输出打印出来. 例如,若你的页上有如下内容,
This is some text
<script>document.write("<P>And some generated text")</script>
当打印时,你只会打出"This is some text", 即使你能在屏幕上看到两行.
使用引号
一定要区分双引号和单引号,因为在HTML中事件处理程序必须用双引号 括起来,参数用单引号,例如:
onClick="window.open('stmtsov.html', 'newWin','toolbar=no,directories=no')">
另外,你可以用前置反斜线(\)对引号进行转义.
定义函数
在HTML页的HEAD部分定义全部函数是一个好习惯.这样,在显示任何内容之前, 所有函数均已定义.否则在页还在装载时,用户可能做一些事情触发事件处理程序, 调用了未定义函数,将导致错误.
创建数组
数组是一个有序的值的集合,利用数组名和索引来引用.例如,一个名为emp的数组存放着雇员的名字,并按雇员编号索引.于是,emp[1]是1号雇员,emp[2]是2号雇员, 依次类推.
JavaScript中没有明确的数组数据类型,但由于数组与对象有类似之处(见 JavaScript Object Model),在JavaScript中,很容易创建数组.你可以定义一个 数组对象类型如下:
function MakeArray(n) {
this.length=n;
for (var i=1; i this[i] = 0
return this
}
}
这样就定义了一个数组,第一个属性length表示数组中元素个数(索引为0),其余各属性初始值为0,索引为大于等于1的整数.
배열 이름과 배열 요소 수를 사용하여 new를 호출하면 배열이 생성됩니다.
emp=new makeArray(20)
이 명령문은 20개의 요소와 초기 값 0을 포함하는 emp라는 배열을 생성합니다.
배열 채우기
배열 요소에 값을 할당하여 배열을 작동합니다. 예:
emp[1]="케이시 존스"
emp[2]="필 레시"
emp[3]="어거스트 웨스트"
잠깐만
객체 배열을 생성할 수도 있습니다. 예를 들어 Employees라는 객체 유형을 정의할 수 있습니다.
함수 직원(empno,name,dept) {
this.empo= empno;
this.name= name;
this.dept= dept;
}
다음 명령문은 이 객체의 배열을 생성합니다.
emp=new MakeArray(3)
emp[1]=new Employee(1,"Casey Jones", "Engineering")
emp[2]=new Employee(2,"Phil Lesh", "Music")
emp[3]=new Employee(3,"August",""Admin)
이때 show_props 함수를 사용합니다(JavaScript Object에 정의됨). Model ) 다음과 같이 배열의 객체를 표시합니다.
for (var n=1; n document.write(show_props(emp[n],"emp") "");
}

JavaScript 문자열 교체 방법 및 FAQ에 대한 자세한 설명 이 기사는 JavaScript에서 문자열 문자를 대체하는 두 가지 방법 인 내부 JavaScript 코드와 웹 페이지의 내부 HTML을 탐색합니다. JavaScript 코드 내부의 문자열을 교체하십시오 가장 직접적인 방법은 대체 () 메소드를 사용하는 것입니다. str = str.replace ( "find", "replace"); 이 메소드는 첫 번째 일치 만 대체합니다. 모든 경기를 교체하려면 정규 표현식을 사용하고 전역 플래그 g를 추가하십시오. str = str.replace (/fi

그래서 여기 당신은 Ajax라는이 일에 대해 배울 준비가되어 있습니다. 그러나 정확히 무엇입니까? Ajax라는 용어는 역동적이고 대화식 웹 컨텐츠를 만드는 데 사용되는 느슨한 기술 그룹을 나타냅니다. 원래 Jesse J에 의해 만들어진 Ajax라는 용어

기사는 JavaScript 라이브러리 작성, 게시 및 유지 관리, 계획, 개발, 테스트, 문서 및 홍보 전략에 중점을 둡니다.

이 기사는 브라우저에서 JavaScript 성능을 최적화하기위한 전략에 대해 설명하고 실행 시간을 줄이고 페이지로드 속도에 미치는 영향을 최소화하는 데 중점을 둡니다.

이 기사는 브라우저 개발자 도구를 사용하여 효과적인 JavaScript 디버깅, 중단 점 설정, 콘솔 사용 및 성능 분석에 중점을 둡니다.

이 기사에서는 jQuery 라이브러리를 사용하여 간단한 사진 회전 목마를 만들도록 안내합니다. jQuery를 기반으로 구축 된 BXSLIDER 라이브러리를 사용하고 회전 목마를 설정하기위한 많은 구성 옵션을 제공합니다. 요즘 그림 회전 목마는 웹 사이트에서 필수 기능이되었습니다. 한 사진은 천 단어보다 낫습니다! 그림 회전 목마를 사용하기로 결정한 후 다음 질문은 그것을 만드는 방법입니다. 먼저 고품질 고해상도 사진을 수집해야합니다. 다음으로 HTML과 일부 JavaScript 코드를 사용하여 사진 회전 목마를 만들어야합니다. 웹에는 다양한 방식으로 회전 목마를 만드는 데 도움이되는 라이브러리가 많이 있습니다. 오픈 소스 BXSLIDER 라이브러리를 사용할 것입니다. BXSLIDER 라이브러리는 반응 형 디자인을 지원 하므로이 라이브러리로 제작 된 회전 목마는

매트릭스 영화 효과를 페이지에 가져 오십시오! 이것은 유명한 영화 "The Matrix"를 기반으로 한 멋진 jQuery 플러그인입니다. 플러그인은 영화에서 클래식 그린 캐릭터 효과를 시뮬레이션하고 사진을 선택하면 플러그인이 숫자로 채워진 매트릭스 스타일 사진으로 변환합니다. 와서 시도해보세요. 매우 흥미 롭습니다! 작동 방식 플러그인은 이미지를 캔버스에로드하고 픽셀 및 색상 값을 읽습니다. data = ctx.getImageData (x, y, settings.grainsize, settings.grainsize) .data 플러그인은 그림의 직사각형 영역을 영리하게 읽고 jQuery를 사용하여 각 영역의 평균 색상을 계산합니다. 그런 다음 사용하십시오

이 기사는 소스 맵을 사용하여 원래 코드에 다시 매핑하여 미니어링 된 JavaScript를 디버그하는 방법을 설명합니다. 소스 맵 활성화, 브레이크 포인트 설정 및 Chrome Devtools 및 Webpack과 같은 도구 사용에 대해 설명합니다.


핫 AI 도구

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

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

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

Clothoff.io
AI 옷 제거제

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

인기 기사

뜨거운 도구

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

PhpStorm 맥 버전
최신(2018.2.1) 전문 PHP 통합 개발 도구

WebStorm Mac 버전
유용한 JavaScript 개발 도구

ZendStudio 13.5.1 맥
강력한 PHP 통합 개발 환경

MinGW - Windows용 미니멀리스트 GNU
이 프로젝트는 osdn.net/projects/mingw로 마이그레이션되는 중입니다. 계속해서 그곳에서 우리를 팔로우할 수 있습니다. MinGW: GCC(GNU Compiler Collection)의 기본 Windows 포트로, 기본 Windows 애플리케이션을 구축하기 위한 무료 배포 가능 가져오기 라이브러리 및 헤더 파일로 C99 기능을 지원하는 MSVC 런타임에 대한 확장이 포함되어 있습니다. 모든 MinGW 소프트웨어는 64비트 Windows 플랫폼에서 실행될 수 있습니다.
