JavaScript基础_1__第十二天

请各位读者添加一下作者的微信公众号,以后有新的文章,将在微信公众号直接推送给各位,非常感谢。


如果您觉得这篇文章还不错,可以去H5专题中查看更多相关文章。

Javascript基础

首先说声抱歉。今日涉及内容难易度不统一,所以很多比较基础的属性直接通过思维导图展示了。

同时需要注意,今日思维导图中的内容和笔记中并不是一一对应的,请读者自行对照查看。

对您造成的困扰,万分抱歉。


这里写图片描述

今日课程预览

这里写图片描述

这里写图片描述

这里写图片描述

这里写图片描述

1. JS 介绍

js(javascript)java没有任何关系,只不过名称看起来有些相同;

netScape-网景公司

这里可以了解一下网景公司的兴衰史,同时也可以了解第一代浏览器的故事,大家可以了解一下“浏览器大战”。

首先大家在学习前要明白几点。

JavaScript 是脚本语言

JavaScript 是一种轻量级的编程语言。

JavaScript 是可插入 HTML 页面的编程代码。

JavaScript 插入 HTML 页面后,可由所有的现代浏览器执行。

注意:

HTML 中的脚本必须位于 <script> 与 </script> 标签之间。

脚本可被放置在 HTML 页面的 <body> 和 <head> 部分中。

<script> 标签

如需在 HTML 页面中插入 JavaScript,请使用 <script> 标签。

<script></script> 会告诉 JavaScript 在何处开始和结束。

JS的组成:(此处请参考思维导图中内容)

  • ECMAScript
  • 文档对象模型(DOM)
  • 浏览器对象模型(BOM)

JS的特点:

  • 弱类型的变量类型
  • 事件驱动
  • 跨平台

那我们学习 JS 能够做什么?

  • 写入 HTML 输出
  • 对事件作出反应
  • 改变 HTML 内容
  • 改变 HTML 图像
  • 改变 HTML 样式
  • 验证输入

2. JS事件和函数的使用

通常,我们需要在某个事件发生时执行代码,比如当用户点击按钮时。

如果我们把 JavaScript 代码放入函数中,就可以在事件发生时调用该函数。

同时我们也可以将<head><body> 中的 JavaScript放在 HTML 文档中,并且我们的放入的脚本是不限量的。

脚本可位于 HTML 的 <body><head> 部分中,或者同时存在于两个部分中。

通常的做法是把函数放入 <head>部分中,或者放在页面底部。

这样就可以把它们安置到同一处位置,不会干扰页面的内容。

注意:

提示:我们把 JavaScript 放到了页面代码的底部,这样就可以确保在 <p> 元素创建之后再执行脚本。

可以把脚本保存到外部文件中。外部文件通常包含被多个网页使用的代码。

外部 JavaScript 文件的文件扩展名是 .js。

如需使用外部文件,请在 <script> 标签的 "src" 属性中设置该 .js 文件。

<script src="myScript.js"></script>

<head><body> 中引用脚本文件都是可以的。

实际运行效果与您在 <script> 标签中编写脚本完全一致。但是需要注意,外部脚本不能包含 <script> 标签。

3. JS引入方式

3.1 头部引入(内部)

<script type="text/javascript">
//内容部分
</script>

例如:

<script type="text/javascript">
//警告   alert()语句 添加一条警告
    alert('网络错误!');
</script>

显示效果如下图所示:

3.2 头部引入js文件(外部)

首先,你需要创建一个目录文件夹例如为js,然后再这个文件夹中创建一个一个后缀为.js的一个js文件,

例如叫做index.js;

index.js中:

alert("网络错误!");

然后在index.html文件中引入外部的js文件来使用;

    <!--第二种方式:引入js文件 外部引入 src是js文件的路径-->
   <script src="js/index.js" type="text/javascript">
    
   </script>

显示效果和第一种方式也是一样:

4. js的变量、js的数据类型

对于接下来要学习的js的变量以及js的数据类型,对有C语言基础的朋友们来说,是非常简单的,非常相似!

变量的定义:变量相当于一个容器,是用来存储数据的。

4.1 变量命名规范:

  • 首字母不能是数字
  • 首字母只能是 $ 或者下划线
  • 不能用中文
  • 多个单词使用驼峰命名法;从第二个单词开始首字母大写
  • 要有语义 见名知义
  • 不要使用关键字或者保留字,防止和系统重名
    var a = 5;//number  数据类型
    var b = 10;
    var str = "15";//字符串类型(string)
    
    alert(a+b);
    
    alert(a+str);//如果一个number类型加上一个字符串类型,则拼接,结果515
    
    var c = a + str;
        
    alert(c);         //+号的功能:1.数学运算 2.字符串连接
    
    var d = a - str;  //-号的功能:1.数学运算
    
    alert(d);

总结:

变量:它是一个容器,都以var来定义变量,数据类型是由它的值来决定的,

例如:var a = 5,所以,变量a的数据类型是number;var b = "15",则b是字符串类(string);

还有一种特殊的情况就是"+"号的作用:

+号的功能:1.数学运算 2.字符串连接;这就是为什么上面代码中的alert(a+str);

警告的结果为515的原因,另外alert()语句的作用只是为了验证结果的,没有什么实质性的意义;

4.2 布尔类型 bool

    var bo1 = true;//布尔类型 结果true和false
    
    //typeof()获取变量的数据类型,(在不知道变量类型的情况下,也可以通过ypeof()获取)
    
    alert(typeof(bo1));

4.3 拓展 undefined类型

    //如果我们不给某个变量设置值,则为undefined类型;

    var color;
    
    alert(typeof color);

4.4 if语句

 //if语句 
 //判断语句    == 判断是否相等,
 //              > 大于
 //              < 小于
 //              >= 大于或者等于
 //              <= 小于或者等于
 //              != 不等于
 //              === 全等于;
 
    var a = 5;//number 数据类型
    var b = 10;
    var c = "5";
    if (a == b) {
        alert("a等于b");
    } else{
        alert("a不等于b");
    }
    
//== 只考虑值是否成立,不考虑类型,
//如果既要考虑值,还得考虑数据类型的话,就用 === 全等于

    if (a == c) {
        alert("a==c成立");
    } else{
        alert("a == c不成立");
    }

注意:

在js当中,"==" 只考虑值是否成立,不考虑变量的数据类型,

如果既要考虑值,还要考虑数据类型的话,就用 "===" 全等于.

4.5 逻辑运算符

    <!-- 
    
     逻辑运算符
     与  或  非;
     与:and  运算符前后的左右条件都成立  &&;
     或:or   运算符前后的条件有一个成立,则结果即为真 ||;
     非:!   对结果取反;
    
    -->
    
    var a = 5;//number 数据类型
    var b = 10;
    var c = "5";//字符串类型(string)
    
    if (a < b && a == c) {
        alert("成立");
    }else{
        alert("不成立");
    }
    
    if (a < b || a > c) {
        alert("成立");
    } else{
        alert("不成立");
    }
    
    if (!(a > b)) {
        alert("取反成立!");
    } else{
        alert("取反不成立!");
    }

4.6 for 循环

 for (var i = 0;i < 10;i++) {
     //警告提示框
        alert(i);
    }

看提示框的提示次数,可知此循环的循环次数为10次;

这里C语言当中for循环当中已经应该非常熟悉了,此处不再多说。

4.7 JS 获取对象

    <body>
      <!--在body当中,创建一个有序列表ol-->
        <ol id="olist">
            <li><span></span>我是li1</li>
            <li><span></span>我是li2</li>
            <li><span></span>我是li3</li>
            <li><span></span>我是li4</li>
            <li><span></span>我是li5</li>
            <li><span></span>我是li6</li>
            <li><span></span>我是li7</li>
            <li><span></span>我是li8</li>
            <li><span></span>我是li9</li>
            <li><span></span>我是li10</li>
        </ol>
    </body>
    
    <script type="text/javascript">
    
    <!--根据id获取标签ol对象-->
    var ol = document.getElementById("olist");
    
    //获取ol有序列表里所有的span标签,第一种方式
    <!--通过ol获取ol列表下的所有span标签-->
    var spans = ol.getElementsByTagName("span");
    
    //或者使用第二种方式:
    var spans = document.querySelectorAll("#ol1 span");
    
    //length 长度 可以通过length求长度
    alert(spans.length);
    
    //如果想获取某单个span标签对象,可以通过下标来获取.例如:
    //spans[0]  下标从0开始
    
    </script>

4.8 JS基础事件(click、mouseover、mouseout)

例如下面代码中的案例:设置一个div的属性为宽为200px、高为200px、颜色为红色;

     <body>
        <!--onclick 当点击时-->
        <!--<input onclick="alert('a')" type="button" name="btn" id="btn1" value="显示" />-->
        <input  type="button" name="" id="btn" value="显示" />
        <div id="div1" style="display: none;"></div>
    </body>

头部引入js

     <script type="text/javascript">
     
    //  获取操作的标签  从文档里通过id去获取标签
    //通常存储在变量里面
    var btn = document.getElementById("btn");//得到button按钮
    var blockDiv = document.getElementById("div");//得到div标签
    
    //当点击button按钮时
    btn.onclick = function(){
    
        //做一次判断
        if (blockDiv.style.display == "none") {
            
            blockDiv.style.display = "block"; //block 属性 display:block 显示
        } else{
            blockDiv.style.display = "none"; //block 属性 display:none 隐藏
        }
        
        //当鼠标移入按钮上时 onmouseover
        btn.onmouseover = function(){   
        
            //改变button上显示的内容
            btn.value = "显示";           
        }
        
        //或者写这个属性兼容性更强
        //btn.onmouseenter = function(){
        //  btn.value = "显示";
        //}
        
        //当鼠标移除时 onmouseout
        btn.onmouseout = function(){
            btn.value = "隐藏";
        }
        
        //或者写这个属性兼容性更强
        //btn.onmouseleave = function(){
        //  btn.value = "隐藏";
        //}
    }
     </script>

通过看下代码实现的效果来验证一下:

(注意点击显示按钮时,div标签的显示与隐藏,以及鼠标移入和移出按钮时,按钮上文字的变化)

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,014评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,796评论 3 386
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,484评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,830评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,946评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,114评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,182评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,927评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,369评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,678评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,832评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,533评论 4 335
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,166评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,885评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,128评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,659评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,738评论 2 351

推荐阅读更多精彩内容