一个初学者的辛酸路程-jQuery
前言:
主要概要:
1、HTML+CSS补充
2、DOM事件
3、jQuery示例
内容概要:
1、布局
代码如下
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
<style>
body{
margin:;
}
.w{
width:980px;
margin: auto;
border:1px solid greenyellow;
}
</style>
</head>
<body>
<div style="background-color: black;color: white;">
<div class="w">标题</div>
</div>
<div>
<div class="w">内容</div>
</div>
</body>
</html>
效果如下:

2、clear both的另外一种写法 (清除浮动)
常规写法就是如下所示:
<body>
<div style="background-color: greenyellow;">
<div style="width: 200px;height: 200px;border: 1px solid red;float: left;"></div>
<div style="width: 200px;height: 200px;border: 1px solid red;float: left;"></div>
<div style="width: 200px;height: 200px;border: 1px solid red;float: left;"></div>
<div style="width: 200px;height: 200px;border: 1px solid red;float: left;"></div>
<div style="width: 200px;height: 200px;border: 1px solid red;float: left;"></div>
<div style="width: 200px;height: 200px;border: 1px solid red;float: left;"></div>
<div style="clear: both;"></div>
</div>
</body>
接着,我们换另外一种写法
注意:有content才会加标签,一般都是这么写,不能写display: none
<style>
.clearfix:after{
content: '.';
display: block;
clear: both;
visibility: hidden;
height:;
}
</style>
所有网站这个都会用到。
以后就写一个公共的CSS,放在引用即可,after是指在这个标签内容的后面

<link rel="stylesheet" href="commons.css">
3、页面布局,拖动浏览器如何让格式不变
第一种方法:
在外面定义一个div给一个固定宽度,如果缩小他会自动出现滚动条。如下图

写法如下:
<div style="width: 800px;">
输入标签
</div>
方法2:@media
<style>
@media (min-width: 800px){
.item{
width:%;
float: left;
}
}
@media (max-width: 700px){
.item{
width:%;
float: left;
}
} </style>
4、事件绑定
submit ,a标签,from表单,这些默认有些默认事件的
也可以自定义一些事件
方式1:点击出现弹框,确定,跳转
<body>
<a href="http://www.baidu.com" onclick=" func();">走你</a>
<script>
function func(){
alert();
false;
}
</script>
</body>
如果我不想让他跳转,需要return一个FALSE即可,如下
<body>
<a href="http://www.baidu.com" onclick="return func();">走你</a>
<script>
function func(){
alert();
return false;
}
</script>
</body>
方式2:
<a href="http://www.baidu.com" id="i1">走你</a>
<script>
document.getElementById('i1').onclick = function () {
alert()
}
</script>
默认阻止写法就是,价格return FALSE;
<body>
<a href="http://www.baidu.com" id="i1">走你</a>
<script>
document.getElementById('i1').onclick = function () {
alert();
return false;
}
</script>
</body>

有何作用?
用户提交数据如果为空,我就在JS上去阻止提交了。

<form action="http://www.baidu.com">
<input type="text" id="user" name="user" />
<input type="submit" value="提交" onclick="return func();">
</form>
<script>
function func(){
var v = document.getElementById('user').value;
if(v.length>){
return true;
}else{
alert('请输入内容')
return false;
}
}
</script>
第二种写法:
<input type="submit" id="sb" value="提交" />
</form> <script>
document.getElementById('sb').onclick = function(){
var v = document.getElementById('user').value;
if(v.length>){
return true;
}else{
alert('请输入内容')
return false;
}
}
</script>
5、有一个绑定事件,我绑定想获取里面的数据。
<body>
<div id="i1" onclick="fuck();">答复</div>
<script>
function fuck(){
var v = document.getElementById('i1').innerText;
alert(v);
}
</script>
this,触发当前目标的对象
<div onclick="fuck(this);">答复</div>
<script>
function fuck(self){
var v = self.innerHTML;
alert(v);
}
</script>
另外一种写法
<div id="i1">答复</div>
<script>
document.getElementById('i1').onclick = function(){
var v = this.innerHTML;
alert(v);
}
</script>

6、点击获取时间去掉里面的关键字,拿开又恢复

代码如下:
<body>
<input type="text" value="请输入关键字" onfocus="fuckFocus(this);"onblur="fuckBlur(this);" />
<input type="button" value="提交">
<script>
/*
当标签获取焦点
*/
function fuckFocus(ths){
var v = ths.value;
if(v == "请输入关键字"){
ths.value = "";
}
}
/*
当标签失去焦点
*/
function fuckBlur(ths){
var v = ths.value;
if(v.length == ){
ths.value = "请输入关键字"
}
} </script>
</body>
this 代表当前标签。
如果获取值,都用.value(表单相关的,比如input系列,select标签)
除了这些,想获取标签中间的值(div span),用innerhtml和innertext。
2者的区别就是innerhtml除了获取值之外还能获取里面的标签,比如a标签或者span标签
如下:

7、同时绑定2个相同的事件
实现效果如下:
点击同时出现2个事件

代码如下:
<div id="i1" onclick="console.log(1);">dfd</div>
<script>
document.getElementById('i1').addEventListener('click',function(){
console.log();
})
</script>
8、触发事件顺序。由内朝外(事件冒泡)
<body>
<div style="height: 400px;width: 400px;background-color: red" onclick="alert(1);">
<div style="height: 300px;width: 300px;background-color: greenyellow" onclick="alert(2);">
<div style="height: 200px;width: 200px;background-color: black" onclick="alert(3);">
</div>
</div>
</div>
</body>

下面,写一个捕获式。通过addEventListener和true来捕获,事件触发顺序就是由外向里了。来控制事件顺序

<div id="i1" style="height: 400px;width: 400px;background-color: red">
<div id="i2" style="height: 300px;width: 300px;background-color: greenyellow" >
<div id="i3" style="height: 200px;width: 200px;background-color: black" >
</div>
</div>
</div> <script>
document.getElementById('i1').addEventListener('click',function(){alert(1);},true);
document.getElementById('i2').addEventListener('click',function(){alert(2);},true);
document.getElementById('i3').addEventListener('click',function(){alert(3);},true);
</script>
给全局绑定事件
event是当前事件的信息
<input type="text" onkeydown="func(this,event);" />
<script>
function func(ths,e){
console.log(ths,e)
}
</script>
全局生效,给Window绑定全局事件
<input type="text" onkeydown="func(this,event);" />
<script>
function func(ths,e){
console.log(ths,e);
}
window.onkeydown = function(e){
console.log(e);
}
</script>
9、通过JS 给任何标签添加提交表单功能

<form id="f1" action="http://www.baidu.com">
<input type="submit" value="提交">
<a onclick = "submitForm();">提交</a> </form>
<script>
function submitForm(){
document.getElementById('f1').submit();
}
</script>
10、给页面刷新,通过代码级别来做
window.location.reload()
获取当前URL和赋值
window.location.href
window.location.href = "http://cn.bing.com"
11、出效果图
jQuery+highchart(专门用来出图)
上官网拿图https://www.hcharts.cn/demo/highcharts

代码如下:
记住,函数式直接从官网找好图,贴上它的代码而来,然后再执行函数即可。
官网找的函数如下:

<body>
<div style="height: 500px;">
<div id="i1"></div>
</div>
<script src="jquery-1.12.4.js"></script>
<script src="highchart/highchart/highcharts.js"></script>
<script>
function createChart(){
$('#i1').highcharts({
chart: {
type: 'bar'
},
title: {
text: 'Historic World Population by Region'
},
subtitle: {
text: 'Source: Wikipedia.org'
},
xAxis: {
categories: ['Africa', 'America', 'Asia', 'Europe', 'Oceania'],
title: {
text: null
}
},
yAxis: {
min: ,
title: {
text: 'Population (millions)',
align: 'high'
},
labels: {
overflow: 'justify'
}
},
tooltip: {
valueSuffix: ' millions'
},
plotOptions: {
bar: {
dataLabels: {
enabled: true
}
}
},
legend: {
layout: 'vertical',
align: 'right',
verticalAlign: 'top',
x: -,
y: ,
floating: true,
borderWidth: ,
backgroundColor: ((Highcharts.theme && Highcharts.theme.legendBackgroundColor) || '#FFFFFF'),
shadow: true
},
credits: {
enabled: false
},
series: [{
name: 'Year 1800',
data: [, , , , ]
}, {
name: 'Year 1900',
data: [, , , , ]
}, {
name: 'Year 2008',
data: [, , , , ]
}]
});
}
createChart();
</script>
</body>
12、利用jQuery找到并操作
<body>
<div id="i1">sdfdf</div>
<script src="jquery-1.12.4.js"></script>
<script>
$('#i1').text('adidas')
</script>
</body>
通过class来修改
<body>
<div class="c1"></div>
<div class="c1"></div>
<div class="c1"></div>
<div class="c1"></div>
<script src="jquery-1.12.4.js"></script>
<script>
$('.c1').text('')
</script>
</body>
2个条件,比如找到class为c1然后ID为i1
$('.c1,#i1').text('666')
等于
$('.c1:eq(2)').text('12345')
地址为:http://jquery.cuishifeng.cn/id.html
可以在这个里面去查找一些功能。

13、点赞实现
用到的知识点如下:
1)追加$('t1').append()在旁边增加一个标签
2)定时器 setInterval
3)透明度
4)位置变化 position: relative
5)字体大小和位置变化
代码如下:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
<style>
.container{
padding:50px;
border:1px solid #dddddd;
}
.item{
position: relative;
width:30px;
}
</style>
</head>
<body>
<div class="container">
<div class="item">
<span>赞</span>
</div>
</div>
<div class="container">
<div class="item">
<span>赞</span>
</div>
</div>
<div class="container">
<div class="item">
<span>赞</span>
</div>
</div>
<div class="container">
<div class="item">
<span>赞</span>
</div>
</div>
</body>
<script src="jquery-1.12.4.js"></script>
<script>
$('.item').click(function(){
AddFavor(this);
});
function AddFavor(self){
var fontSize = ;
var top = ;
var right = ;
var opacity = ; var tag = document.createElement('span');
$(tag).text('+1');
$(tag).css('color','green');
$(tag).css('fontSize',fontSize + "px");
$(tag).css('position','absolute');
$(tag).css('right',right + "px");
$(tag).css('top',top + "px");
$(tag).css('opacity',opacity);
$(self).append(tag); var obj = setInterval(function(){
fontSize = fontSize + ;
top = top - ;
right = right - ;
opacity = opacity - 0.1; $(tag).css('fontSize',fontSize + "px");
$(tag).css('right',right + "px");
$(tag).css('top',top + "px");
$(tag).css('opacity',opacity); // 删除定时器和去除+1的标签
if (opacity < ){
clearInterval(obj);
$(tag).remove()
} },);
}
</script>
</html>
效果如下:

一个初学者的辛酸路程-jQuery的更多相关文章
- 一个初学者的辛酸路程-依旧Django
回顾: 1.Django的请求声明周期? 请求过来,先到URL,URL这里写了一大堆路由关系映射,如果匹配成功,执行对应的函数,或者执行类里面对应的方法,FBV和CBV,本质上返回的内容都是字符串 ...
- 一个初学者的辛酸路程-初识Django
前言: 主要是关于JavaScript的高级部分以及Django 主要内容: 一.jQuery 事件绑定: DOM事件绑定: -直接在标签上绑定 第一种: $('.title').click(func ...
- 一个初学者的辛酸路程-python操作SQLAlchemy-13
前言 其实一开始写blog,我是拒绝的,但是,没办法,没有任何理由抗拒.今天呢,要说的就是如何使用Python来操作数据库. SQLAlchemy SQLAlchemy是Python编程语言下的一款O ...
- 一个初学者的辛酸路程-FTP-9
前言 今天,我要描述一个FTP的故事 主要内容 嗯,今天主要以阶梯性的形式来做一个FTP项目. 第一步: 我要实现这么一个功能,一个FTP客户端,1个FTP服务端,2端建立连接以后可以进行通讯. 服务 ...
- 一个初学者的辛酸路程-socket编程-8
前言: 你会发现会网络是多么幸福的事情 主要内容: socket 概念: socket本质上就是2台网络互通的电脑之间,架设一个通道,两台电脑通过这个通道来实现数据的互相传递.我们知道网络通信都是基于 ...
- 一个初学者的辛酸路程-Python基础-3
前言 不要整天沉迷于学习-. 字典 一.我想跟你聊聊字典 1.为何要有字典? 大家有没有想过为什么要有字典?有列表不就可以了吗? 也许大家会这么认为,我给大家举个例子,大家就明白了. 比如说,我通讯录 ...
- 一个初学者的辛酸路程-了解Python-2
前言 blog花了一上午写的,结果笔记本关机了,没有保存,找不到了,找不到了啊,所以说,你看的每一篇blog可能都是我写了2次以上的--.哎!! 代码改变世界,继续......... Python基础 ...
- 一个初学者的辛酸路程-初识Python-1
前言 很喜欢的一句话,与诸位共勉. 人的一切痛苦,本质上都是对自己无能的愤怒----王小波. 初识Python 一.它的爸爸是谁 首先,我们需要认识下面这位人物. 他是Python的创始人,吉多范罗苏 ...
- 一个初学者的辛酸路程-继续Django
问题1:HTTP请求过来会先到Django的那个地方? 先到urls.py ,里面写的是对应关系,1个URL对应1个函数名. 如果发URL请求过来,到达这里,然后帮你去执行指定的函数,函数要做哪些事 ...
随机推荐
- 装箱问题,贪心(POJ1017)
题目链接:http://poj.org/problem?id=1017 解题报告: #include<stdio.h> int main() { int n,a,b,c,d,e,f,x,y ...
- cudpp库使用说明
所有信息是我个人在使用过程中的小小经验,不是什么权威性文档,旨在帮助需要研究此类信息的朋友少走点弯路. 整个项目的主函数,一切从这里开始 在cudpp_testrig右键属性页里找到调试,在命令行里输 ...
- 【Java】对象、类(抽象类与内部类)、接口
博文内容概况 对象和类 抽象类 接口 内部类 对象和类 对象是对客观事物的抽象,类是对对象的抽象.类是一种数据类型,其外观和行为由用户定义.类中可以设置两种类型的元素:字段(有时被称为数据成员)和方法 ...
- iOS第三方支付(支付宝)
使用支付宝进行一个完整的支付功能,大致有以下步骤: 与支付宝签约,获得商户ID(partner)和账号ID(seller) 下载相应的公钥私钥文件(加密签名用) 下载支付宝SDK 生成订单信息 调用支 ...
- 【iOS】史上最全的iOS持续集成教程 (下)
:first-child{margin-top:0!important}.markdown-body>:last-child{margin-bottom:0!important}.markdow ...
- 关于Ubuntu 16.04 pip安装Docker-Compose
$ sudo apt-get update 安装pip: $ sudo apt-get install python-pip 卸载旧版本docker-compose: $ sudo pip unins ...
- python导包学习总结
python初学者,对于导包纠结了不少时间,总结分享,持续前进~ Python导包的两种方法: 1.1 from 包.模块 import 方法名,调用时直接使用方法名() 1.2 from 包. ...
- Spring Boot Shiro权限管理--自定义 FormAuthenticationFilter验证码整合
思路shiro使用FormAuthenticationFilter进行表单认证,验证校验的功能应该加在FormAuthenticationFilter中,在认证之前进行验证码校验. 需要写FormAu ...
- 解决php文字及图片显示乱码的问题
我们在学习PHP的过程中,想必有不少新手朋友们都遇到过乱码的问题,解决乱码问题不仅是小白们必须掌握的基础知识点,也是最为常见的PHP面试题之一.下面就结合简单代码示例给大家总结介绍下,PHP遇到乱码时 ...
- JavaScript高级程序设计第三版.CHM【带实例】
从驱动全球商业.贸易及管理领域不计其数的复杂应用程序的角度来看,说 JavaScript 已经成为当今世界上最流行的编程语言一点儿都不为过. JavaScript 是一种非常松散的面向对象语言,也是 ...