0
点赞
收藏
分享

微信扫一扫

java web 学习记录——javascript

大南瓜鸭 2022-02-08 阅读 80

##JavaScript:一门客户端脚本语言(脚本语言不需要编译就可以被浏览器解析执行了)
   JavaScript 能够以不同方式“显示”数据:
   1. 使用 window.alert() 写入警告框
   2. 使用 document.write() 写入 HTML 输出
   3. 使用 innerHTML 写入 HTML 元素
   4. 使用 console.log() 写入浏览器控制台


#ECMAScript:客户端脚本语言的标准
       1、与html结合方式
          1、内部:*定义<script>(定义在任何位置,可以是多个,会影响执行顺序)标签体内容就是js代码
          2、外部:*定义<script>通过src属性引入外部的js文件
       2、注释:单行://        多行:/* */
       3、数据类型:原始数据类型(NaN类型:不是数字的数字类型)和引用数据类型
       4、变量:Java语言是强类型语言(类型固定),JavaScript是弱类型语言 var 变量名 = 初始值  用typeof来获知是什么类型 
       5、运算符:
       6、特殊语法:1、语句以分号结尾,如果一行只有一条语句则分号可以省略(不建议)2、变量的定义使用var(变量是局部变量) 也可以不使用(全局变量)
       7、流程控制语句:if else。。。。 
#BOM:
    1. 概念:Browser Object Model 浏览器对象模型
        * 将浏览器的各个组成部分封装成对象。
    2. 组成:
        * Window:窗口对象
        * Navigator:浏览器对象
        * Screen:显示器屏幕对象
        * History:历史记录对象
        * Location:地址栏对象
    3. Window:窗口对象
        1. 创建
        2. 方法
             1. 与弹出框有关的方法:
                alert()    显示带有一段消息和一个确认按钮的警告框。
                confirm()    显示带有一段消息以及确认按钮和取消按钮的对话框。
                    * 如果用户点击确定按钮,则方法返回true
                    * 如果用户点击取消按钮,则方法返回false
                prompt()    显示可提示用户输入的对话框。
                    * 返回值:获取用户输入的值
             2. 与打开关闭有关的方法:
                close()    关闭浏览器窗口。
                    * 谁调用我 ,我关谁
                open()    打开一个新的浏览器窗口
                    * 返回新的Window对象
             3. 与定时器有关的方式
                setTimeout()    在指定的毫秒数后调用函数或计算表达式。
                    * 参数:
                        1. js代码或者方法对象
                        2. 毫秒值
                    * 返回值:唯一标识,用于取消定时器
                clearTimeout()    取消由 setTimeout() 方法设置的 timeout。
                setInterval()    按照指定的周期(以毫秒计)来调用函数或计算表达式。
                clearInterval()    取消由 setInterval() 设置的 timeout。
        3. 属性:
            1. 获取其他BOM对象:
                history
                location
                Navigator
                Screen:
            2. 获取DOM对象
                document
        4. 特点
            * Window对象不需要创建可以直接使用 window使用。 window.方法名();
            * window引用可以省略。  方法名();
    4. Location:地址栏对象
        1. 创建(获取):
            1. window.location
            2. location
        2. 方法:
            * reload()    重新加载当前文档。刷新
        3. 属性
            * href    设置或返回完整的 URL。
    5. History:历史记录对象
        1. 创建(获取):
            1. window.history
            2. history

        2. 方法:
            * back()    加载 history 列表中的前一个 URL。
            * forward()    加载 history 列表中的下一个 URL。
            * go(参数)    加载 history 列表中的某个具体页面。
                * 参数:
                    * 正数:前进几个历史记录
                    * 负数:后退几个历史记录
        3. 属性:
            * length    返回当前窗口历史列表中的 URL 数量。
#DOM:(控制html文档的内容)
    *代码:获取页面标签(元素)对象Element
       *document.getElementById("Id值"):通过元素的Id获取元素对象
    *操作Element对象:
      1. 修改属性值
      2. 修改标签体内容
    * 概念: Document Object Model 文档对象模型
        * 将标记语言文档的各个组成部分,封装为对象。可以使用这些对象,对标记语言文档进行CRUD的动态操作
    * W3C DOM 标准被分为 3 个不同的部分:
        * 核心 DOM - 针对任何结构化文档的标准模型
            * Document:文档对象
            * Element:元素对象
            * Attribute:属性对象
            * Text:文本对象
            * Comment:注释对象
            * Node:节点对象,其他5个的父对象
        * XML DOM - 针对 XML 文档的标准模型
        * HTML DOM - 针对 HTML 文档的标准模型
    * 核心DOM模型:
        * Document:文档对象
            1. 创建(获取):在html dom模型中可以使用window对象来获取
                1. window.document
                2. document
            2. 方法:
                1. 获取Element对象:
                    1. getElementById()    : 根据id属性值获取元素对象。id属性值一般唯一
                    2. getElementsByTagName():根据元素名称获取元素对象们。返回值是一个数组
                    3. getElementsByClassName():根据Class属性值获取元素对象们。返回值是一个数组
                    4. getElementsByName(): 根据name属性值获取元素对象们。返回值是一个数组
                2. 创建其他DOM对象:
                    createAttribute(name)
                    createComment()
                    createElement()
                    createTextNode()
            3. 属性
        * Element:元素对象
            1. 获取/创建:通过document来获取和创建
            2. 方法:
                1. removeAttribute():删除属性
                2. setAttribute():设置属性
        * Node:节点对象,其他5个的父对象
            * 特点:所有dom对象都可以被认为是一个节点
            * 方法:
                * CRUD dom树:
                    * appendChild():向节点的子节点列表的结尾添加新的子节点。
                    * removeChild()    :删除(并返回)当前节点的指定子节点。
                    * replaceChild():用新节点替换一个子节点。
            * 属性:
                * parentNode 返回节点的父节点。
    * HTML DOM
        1. 标签体的设置和获取:innerHTML
        2. 使用html元素对象的属性
        3. 控制元素样式
            1. 使用元素的style属性来设置
                如:
                     //修改样式方式1
                    div1.style.border = "1px solid red";
                    div1.style.width = "200px";
                    //font-size--> fontSize
                    div1.style.fontSize = "20px";
            2. 提前定义好类选择器的样式,通过元素的className属性来设置其class属性值。

##BootStrap:一个前端开发框架
       *好处:
        1. 定义了很多的css样式和js插件,开发人员可以直接使用这些样式和插件(Bootstrap中文网文档)
        2. 响应式布局:同一套页面可以兼容不同分辨率的设备
       *快速入门:
        1. 下载Bootstrap
        2. 在项目中将三个文件夹复制
        3. 创建html页面,引入必要的资源文件
        *引入代码
        <!doctype html>
        <html lang="zh-CN">
        <head>
            <meta charset="utf-8">
            <meta http-equiv="X-UA-Compatible" content="IE=edge">
            <meta name="viewport" content="width=device-width, initial-scale=1">
            <!-- 上述3个meta标签*必须*放在最前面,任何其他内容都*必须*跟随其后! -->
            <title>Bootstrap Hello world</title>
        
            <!-- Bootstrap -->
            <link rel="stylesheet" href="bootstrap/css/bootstrap.min.css">
        </head>
        <body>
        <h1>Hello !</h1>
        <!-- jQuery (Bootstrap 的所有 JavaScript 插件都依赖 jQuery,所以必须放在前边) -->
        <script src="bootstrap/js/jquery.js"></script>
        <!-- 加载 Bootstrap 的所有 JavaScript 插件。你也可以根据需要只加载单个插件。 -->
        <script src="bootstrap/js/bootstrap.min.js" ></script>
        </body>
        </html>

## 响应式布局
  *实现:依赖于栅格系统:将一行平均分成12个格子,可以指定元素占几个格子
  *步骤:
   1.定义容器,相当于table
      *容器分类
      1. container 固定宽度两边有留白 各个设备不同
      2. container-fluid  每种设备都是百分百宽度
   2.定义行,相当于tr 样式row
   3.定义元素,指定该元素在不同设备上,所占的格子数目  样式:col-设备代号-格子数目
      *设备代号:xs  sm  md  lg
   *注意:超过了过后自动换行 栅格类向上兼容 向下不兼容      

## CSS样式和JS插件
 *全局CSS样式:
     *按钮 class="btn btn-primary"
     *图片
     *表格
     *表单
 *组件:
     *导航条
     *分页条
 *插件:
     *轮播图     

举报

相关推荐

0 条评论