js

特性:js是弱类型(动态类型)语言,在声明变量时无需指定类型且在运行时可赋值为任意类型;不自带样式,不会直接影响页面的样式、布局、排版; 
js功能强大,能做很多事情:操作页面,操作浏览器;计算,逻辑,数据处理,读写文件;发网络请求;写后端服务(Node.js);移动端app;嵌入式;游戏开发,脚本自动化等等
1.js操作页面与浏览器: DOM和BOM的根都是window对象
1.1.DOM:文档对象模型(Document Object Model),浏览器把html转化成js能看懂的"对象树"dom;js通过dom提供的api操作网页内容(HTML 里的 div、文字、样式)
BOM:浏览器对象模型(Browser Object Model),操作浏览器窗口(跳转、刷新、地址栏、弹窗、历史、存储);原理同上
DOM常见操作:
找元素:querySelector、getElementById
改内容:innerHTML、textContent
改样式:style.color、style.width
改属性:src、href、class
加事件:onclick、addEventListener
增删元素:createElement、appendChild、remove
例子:
document.querySelector('.box').style.width = '500px';//找到页面上class="box"的元素,把它的宽度改成500px
document.body.innerHTML = '<div>新内容</div>'; //把网页body里原来的所有内容清空替换成新的HTML结构
1.2.BOM常见操作: 
弹窗相关:
alert('提示')
confirm('确定吗?')
prompt('输入内容')
页面跳转,刷新:
// 跳转到别的页面
location.href = 'https://www.baidu.com' 
// 刷新页面
location.reload() //location就是bom对象
浏览器历史:
history.back()    // 返回上一页
history.forward() // 前进一页
定时器:
setTimeout(() => {}, 1000)
setInterval(() => {}, 1000)
窗口大小,滚动:
window.innerWidth  // 窗口宽度
window.scrollY     // 滚动距离
window.scrollTo(0, 0) // 滚到顶部
本地存储:
localStorage.setItem('name', '张三')
sessionStorage 
location、setTimeout、localStorage、alert、history都属于bom提供的对象
2.网络请求:
发展历史:

方案 本质 出现时间 地位
XMLHttpRequest(XHR) AJAX 原生底层 1999 祖师爷
jQuery.ajax 封装 XHR 2006 曾经的王者
fetch 浏览器原生新 API 2015 原生替代方案
axios 封装 XHR + Promise 2016 现在行业标准

现在用的最多的就是axios,一个专门用于http网络请求的js库,基于XMLHttpRequest,Promise风格:统一用 .then() / .catch(),链式清晰
4xx/5xx 自动 reject
支持请求 / 响应拦截器
支持取消请求、超时、上传进度
随着Vue、React流行,axios彻底取代jQuery.ajax

常见的js库:jQuery,axios,lodash,moment/dayjs,vue,react
jQuery:是一个非常经典,老牌的js库,用更少代码,更方便地操作DOM和做AJAX请求;
主要解决两大痛点:抹平浏览器差异;简化DOM操作、事件、动画、AJAX请求;后来 Vue、React 出现,大家不再大量操作 DOM,jQuery 就慢慢退出主流
lodash:标准实用的js工具类库,更轻松地处理数组、对象、字符串等常见数据结构,进行深拷贝,数组去重,防抖节流,安全取值,遍历、过滤、分组等操作

项目结构:
assets目录: 项目本身的静态资源(核心)
项目自己的、必须的、框架自带的全部放这里。
里面一般有:
assets/js/ (核心 JS:jquery、bootstrap、模板主 JS)
assets/css/ (核心样式)
assets/img/ (系统图片)
assets/fonts/(字体图标)
misc目录: 杂项、工具、第三方插件(非核心)
misc/js/

前端框架:Bootstrap

Bootstrap是一个j基于html,css,js开发的前端开源框架,支持开发者快速构建网站界面;框架包含导航条,分页等组件及13个jQuery插件;

基本结构:Bootstrap提供了一个带有网格系统,链接样式,背景的基本结构。

CSS:提供了全局的CSS设置,定义了基本的html元素样式,可扩展的class以及一个先进的网格系统;

组件:Bootstrap 包含了十几个可重用的组件,用于创建图像、下拉菜单、导航、警告框、弹出框等等。组件由一套可复用的代码,由html元素,配套css,js组成;

js插件:Bootstrap自带了13个jQuery插件,这些插件为Bootstrap中的组件赋予了“生命”。其中包括:模式对话框、标签页、滚动条、弹出框等。

Logo

AtomGit 是由开放原子开源基金会联合 CSDN 等生态伙伴共同推出的新一代开源与人工智能协作平台。平台坚持“开放、中立、公益”的理念,把代码托管、模型共享、数据集托管、智能体开发体验和算力服务整合在一起,为开发者提供从开发、训练到部署的一站式体验。

更多推荐