### 笔记内容导图:
### 
**一、js的String对象**
* 查看W3CSchool文档,有该对象详细属性方法。

* 常用属性
* length :声明了该字符串中的字符数。
~~~
<script type="text/javascript">
var a = "drby";
document.write(a.length); //4
</script>
~~~
* 常用方法
* 与html相关的方法
* bold() : 使用粗体显示字符串。
~~~
<script type="text/javascript">
var str="Hello world!"
document.write(str.bold()) //helloworld!显示为粗体 【发现语句结束不加分号也能运行成功QAQ】
</script>
~~~
* fontcolor() : 使用指定的颜色来显示字符串。
~~~
<script type="text/javascript">
var str="Hello world!"
document.write(str.fontcolor("Red"))
</script>
~~~
* fontsize() : 使用指定的尺寸来显示字符串
~~~
<script type="text/javascript">
var str="Hello world!"
document.write(str.fontsize(7))
</script>
~~~
* link(): 将字符串显示为链接。
~~~
<script type="text/javascript">
var str="this is a url"
document.write(str.link("http://www.w3school.com.cn"))
</script>
~~~
* sub() : 把字符串显示为下标。 sup() : 把字符串显示为上标。
~~~
<script type="text/javascript">
var str="Hello world!下标"
document.write(str.sub())
var str1="Hello world!上标"
document.write(str1.sup())
</script>
~~~

* 与java相似的方法()更多例子用法查看w3c文档
* concat() : 连接字符串。
* charAt() : 返回在指定位置的字符。
* indexOf() : 检索字符串。即返回字符位置
* split() : 把字符串分割为字符串数组。
* replace() : 替换与正则表达式匹配的子串。
* substr() substring() :
~~~
<script type="text/javascript">
//concat方法
var str1 = "abc";
var str2 = "dfg";
document.write(str1.concat(str2));
document.write("<hr>");
//charAt方法
var str3 = "abcdefg";
document.write(str3.charAt(20)); //字符位置不存在,返回空字符串
document.write(str3.charAt(3));
document.write("<hr>");
//indexOf方法
var str4 = "poiuyt";
document.write(str4.indexOf("y"));
document.write(str4.indexOf("w")); //字符不存在,返回-1
document.write("<hr>");
//split方法 【更多例子用法查看w3c文档】
var str5 = "a-b-c-d";
var arr1 = str5.split("-");
document.write("length: "+arr1.length + "<br />");
var str="How are you doing today?"
document.write(str.split(" ") + "<br />")
document.write(str.split("") + "<br />")
document.write(str.split(" ",3))
document.write("<hr>");
//replace方法 【更多例子用法查看w3c文档】
var str6 = "abcd";
document.write(str6);
document.write("<br/>");
document.write(str6.replace("a","Q")); //次处传两个参数,第一个原始字符,第二个是要替换成的字符
document.write("<hr>");
//substr方法
var str7 = "abcdefghuiop";
document.write(str7.substr(5,5)); //fghui 从第五位开始,向后截取几位
document.write("<hr>");
//substring方法
var str8 = "abcdefghuiopqrst";
document.write(str7.substring(3,5)); //de 从第几位开始到第几位结束 [3,5) 包左不包右
</script>
~~~

需要注意的是,JavaScript 的字符串是不可变的(immutable),String 类定义的方法都不能改变字符串的内容。像 String.toUpperCase() 这样的方法,返回的是全新的字符串,而不是修改原始字符串。
**二、js的Array对象**
* 常用属性
* length :设置或返回数组中元素的数目。
~~~
<script type="text/javascript">
var arr = new Array(3)
arr[0] = "John"
arr[1] = "Andy"
arr[2] = "Wendy"
document.write("Original length: " + arr.length)
document.write("<br />")
arr.length=5
document.write("New length: " + arr.length)
</script>
//结果:
//Original length: 3
//New length: 5
~~~
* 常用方法
* concat(): 连接两个或更多的数组,并返回结果。
* 该方法不会改变现有的数组,而仅仅会返回被连接数组的一个副本。即返回一个新的数组。
* join(): 把数组的所有元素放入一个字符串。元素通过指定的分隔符进行分隔。
* push(): 向数组的末尾添加一个或更多元素,并返回新的长度。
* push() 方法可把它的参数顺序添加到 arrayObject 的尾部。它直接修改 arrayObject,而不是创建一个新的数组。push() 方法和 pop() 方法使用数组提供的先进后出栈的功能。
* 如果添加的是一个数组,这个时候把数组当做一个整体字符串添加进去
* pop(): 删除并返回数组的最后一个元素
* pop() 方法将删除 arrayObject 的最后一个元素,把数组长度减 1,并且返回它删除的元素的值。如果数组已经为空,则 pop() 不改变数组,并返回 undefined 值。
* reverse(): 颠倒数组中元素的顺序。
* 该方法会改变原来的数组,而不会创建新的数组。
~~~
<script type="text/javascript">
//concat方法
var arr1 = [1,2,3];
var arr2 = [4,5,6];
var arr3 = [7,8,9];
document.write(arr1.concat(arr2) +"<br/>"); //1,2,3,4,5,6
document.write(arr1.concat(arr2,arr3)); //1,2,3,4,5,6,7,8,9
document.write("<hr>");
//join方法
var arr4 = new Array(3)
arr4[0] = "George"
arr4[1] = "John"
arr4[2] = "Thomas"
document.write(arr4.join() +"<br/>") //George,John,Thomas
document.write(arr4.join(".")) //George.John.Thomas
document.write("<hr>");
//push方法
var arr5 = new Array(3);
arr5[0] = "tom";
arr5[1] = "lucy";
arr5[2] = "jack";
document.write("old array: "+arr5);
document.write("<br/>");
document.write("old length:"+arr5.length);
document.write("<br/>");
document.write("new length: "+arr5.push("zhangsan"));
document.write("<br/>");
document.write("new array: "+arr5);
document.write("<br/>","<br/>");
var arr6 = ["www","qqq"];
var arr7 = ["aaa","bbb","ccc"];
document.write("old array:"+arr6 +"<br/>");
document.write("old length:"+arr6.length +"<br/>");
document.write("new length:"+arr6.push(arr7) +"<br/>"); //结果3 不是5 ,因为把arr7当做一个整体字符串(即一个元素)添加到arr6
document.write("new array: "+arr6);
for(var i=0;i<arr6.length;i++) {
alert(arr6[i]);
}
document.write("<hr>");
//pop方法
var arr8 = ["zhangsan","lisi","wangwu","zhaoliu"];
document.write("old array: "+arr8 +"<br/>");
document.write("return: "+arr8.pop() +"<br/>");
document.write("new array: "+arr8);
document.write("<hr>");
//reverser方法
var arr9 = ["zhangsan1","lisi1","zhaoliu1","niuqi1"];
document.write("old array: "+arr9);
document.write("<br/>");
document.write("new array:"+arr9.reverse());
</script>
~~~

**三、js的Date对象**
* 在java里面获取当前时间
~~~
Date date = new Date();
//格式化
toLocaleString() //xxxx年xx月xx日 xx:xx:xx
~~~
* js里面获取当前时间
~~~
<script type="text/javascript">
//获取当前时间
var date = new Date();
document.write(date); // Sat May 28 2016 22:33:17 GMT+0800 (中国标准时间)
//转换成习惯的格式
document.write("<hr/>");
document.write(date.toLocaleString()); //2016年5月28日 22:33:17
</script>
~~~
* 获取当前的年方法 getFullYear()
~~~
var date = new Date();
document.write("year: "+date.getFullYear()); //year: 2016
~~~
* 获取当前的月方法 getMonth()
~~~
<script type="text/javascript">
//返回的是 0-11月,如果想要得到准确的值,加1
var date = new Date();
var date1 = date.getMonth()+1;
document.write("month: "+date1);
</script>
~~~
* 获取当前的星期 getDay()
~~~
<script type="text/javascript">
//返回的是 (0 ~ 6)
//外国朋友,把星期日作为一周的第一天,星期日返回的是0,而星期一到星期六 返回的是 1-6
var date = new Date();
document.write("week: "+date.getDay());
</script>
~~~
* 获取当前的日 getDate()
~~~
<script type="text/javascript">
//得到当前的天 1-31
var date = new Date();
document.write("day: "+date.getDate());
</script>
~~~
* 获取当前的小时 getHours()
~~~
<script type="text/javascript">
//得到当前的小时 0~23
var date = new Date();
document.write("hour: "+date.getHours());
</script>
~~~
* 获取当前的分钟 getMinutes()
~~~
<script type="text/javascript">
var date = new Date();
document.write("minute: "+date.getMinutes());
</script>
~~~
* 获取当前的秒 getSeconds()
~~~
var date = new Date();
document.write("second: "+date.getSeconds());
~~~
* 获取毫秒数 getTime() 【返回的是1970 1 1 至今的毫秒数】 setTime() 根据毫秒数设置时间
~~~
var date = new Date();
document.write("second: "+date.getTime());
~~~
* 应用场景:
常用在防止浏览器缓存时候 ,比如银行网站就不需要缓存
使用毫秒数处理缓存的效果(不有缓存) http://www.baidu.com?毫秒数
****四、js的Math对象****
* Math 对象并不像 Date 和 String 那样是对象的类,因此没有构造函数 Math(),像 Math.sin() 这样的函数只是函数,不是某个对象的方法。无需创建它,通过把 Math 作为对象使用就可以调用其所有属性和方法。
* 数学的运算。里面的都是静态方法,使用可以直接使用 Math.方法()
* ceil(x): 向上舍入
~~~
<script type="text/javascript">
var mm = 10.3;
//不用创建math对象
document.write(Math.ceil(mm)); //11
</script>
~~~
* floor(x):向下舍入
* round(x):四舍五入
* random():得到随机数(伪随机数)(返回 0.0 ~ 1.0 之间的随机数。)
* 得到0-9的随机数
~~~
Math.random()*10
Math.floor(Math.random()*10)); //Math.floor舍去小数部分
~~~
********五、js的全局函数********
******** ********
* 由于不属于任何一个对象,直接写名称使用
* 常用函数:
* eval() : 执行js代码(如果字符串是一个js代码,使用方法直接执行)
~~~
<script type="text/javascript">
var str = "alert('1234');";
alert(str); //alert('1234');
eval(str); //1234
</script>
~~~
* encodeURI() : 把字符串作为 URI 进行编码。【进行url跳转时可以整体使用encodeURI】
* decodeURI() : 对 encodeURI() 函数编码过的 URI 进行解码。
* encodeURIComponent() : 把字符串编码为 URI 组件。
* decodeURIComponent() : 解码一个编码的 URI 组件。
~~~
<script type="text/javascript">
var str1 = "测试中文aaa1234";
var encode1 = encodeURI(str1); //encodeURI编码
document.write(encode1);
document.write("<hr>");
var decode1 = decodeURI(str1); //decodeURI解码
document.write(decode1);
document.write("<hr>");
</script>
//escape / unescape 对字符串进行unicode编码
//escape不编码字符有69个:*,+,-,.,/,@,_,0-9,a-z,A-Z
//encodeURI不编码字符有82个:!,#,$,&,',(,),*,+,,,-,.,/,:,;,=,?,@,_,~,0-9,a-z,A-Z
//encodeURIComponent不编码字符有71个:!, ',(,),*,-,.,_,~,0-9,a-z,A-Z
~~~
* isNaN() : 检查某个值是否是数字。
~~~
<script type="text/javascript">
var str = "aaa";
alert(isNaN(str)); //true
</script>
// 如果是数字,返回false ; 如果不是数字,返回true
~~~
* parseInt() : 解析一个字符串,并返回一个整数。类型转换
~~~
<script type="text/javascript">
var str = "123"
alert(str+7); //1237
alert(parseInt(str)+7); //130
</script>
~~~
********六、js的函数的重载 ********
* 什么是重载? 一个类中的方法名相同,但是参数个数或参数类型不同.
* js的重载是否存在?不存在 调用最后一个方法 (备注:js的继承?)
~~~
<script type="text/javascript">
function add(a,b){
return a+b;
}
function add(a,b,c){
return a+b+c;
}
function add(a,b,c,d){
return a+b+c+d;
}
alert(add(2,3)); //NAN
alert(add(2,3,4)); //NAN
alert(add(2,3,4,5)); //14 根据运行结果:执行的是最后一个方法
</script>
//把三个参数的方法放到最后
<script type="text/javascript">
alert(add(2,3)); //NaN
alert(add(2,3,4)); //9
alert(add(2,3,4,5)); //9 根据运行结果:执行的是最后一个方法
function add(a,b){
return a+b;
}
function add(a,b,c,d){
return a+b+c+d;
}
function add(a,b,c){
return a+b+c;
}
</script>
~~~
* 可以通过其他方式模拟重载的效果 (通过aruguments数组来实现,把传替的参数保存到数组中)
* 例题:js里面是否存在重载?(面试题)
* js里面不存在重载。
* 但是可以通过其他方式模拟重载的效果 (通过aruguments数组来实现)
~~~
<script type="text/javascript">
alert(add(2,3)); //5
alert(add(2,3,4)); //9
alert(add(2,3,4,5)); //14
function add(){
if(arguments.length == 2) {
return arguments[0]+arguments[1];
} else if (arguments.length == 3) {
return arguments[0]+arguments[1]+arguments[2];
} else if (arguments.length == 4) {
return arguments[0]+arguments[1]+arguments[2]+arguments[3];
} else {
return 0;
}
}
</script>
~~~
********七、js的bom对象********
******** ********
* bom:broswer object model: 浏览器对象模型
* bom对象
* navigator: 获取客户机的信息(浏览器的信息)
* screen: 获取客户机屏幕的信息
~~~
//更多查看w3c文档
<script type="text/javascript">
document.write(navigator.appName);
document.write("<br/>");
document.write(navigator.appCodeName);
document.write("<br/>");
document.write(screen.width);
document.write("<br/>");
document.write(screen.height);
document.write("<br/>");
document.write(location.href);
</script>
~~~
* location: 请求url地址
* href属性(两个作用)
* 1.获取到请求的url地址
~~~
<script type="text/javascript">
document.write(location.href); // file:///D:/cn.yjk/1.html
</script>
~~~
* 2.设置url地址
* 需求:页面上安置一个按钮,按钮上绑定一个事件,当我点击这个按钮,页面可以跳转到另外一个页面
~~~
<body>
<!-- 鼠标点击事件 onclick="js的方法;" -->
<input type="button" value="tiaozhuan" onclick="href1();"/>
</body>
<script type="text/javascript">
function href1(){
//alert("aaaa");
location.href = "hello.html";
}
</script>
~~~
* history:请求的url的历史记录
* 创建三个页面: 1、创建第一个页面 a.html 写一个超链接 到 b.html ;2、创建b.html 超链接 到 c.html ;3、创建c.html
* 到访问的上一个页面:history.back(); 或者 history.go(-1);
* 到访问的下一个页面:history.forward(); 或者 history.go(1);
~~~
<body>
<!-- 鼠标点击事件 onclick="js的方法;" -->
<input type="button" value="back" onclick="back1();"/>
<input type="button" value="next" onclick="next1();"/>
<h1>BBBBB</h1>
</body>
<script type="text/javascript">
//到上一个页面AAAAA.html
function back1(){
history.back();
}
//到下一个页面CCCCC.html
function next1(){
history.forward();
}
</script>
~~~
* window(重点掌握):
* 表示一个浏览器窗口或一个框架
* 顶层对象{所用的bom对象\[比如history、navigator等等\] 都是在window里面操作的;所以可以只写 document,而不必写 window.document。只写 alert(),而不必写 Window.alert()。只写history.back(),而不必写window.history.back()。等等}
* 方法
* window.alert():页面弹出一个框,显示内容 简写alert()
* confirm():显示带有一段消息以及确认按钮和取消按钮的对话框。
~~~
var flag = window.confirm("显示的内容");
~~~
* prompt():显示可提示用户进行输入的对话框。
~~~
window.prompt("please input : ", "0");
window.prompt("显示的内容","输入框里面的默认值");
~~~
* open(): 打开一个新的浏览器窗口或查找一个已命名的窗口。
~~~
<script type="text/javascript">
//window.open(URL,name,features,replace) open("打开的新窗口的地址url","","窗口特征,比如窗口宽度和高度")
//创建一个按钮,点击这个按钮,打开一个新的窗口
window.open("hello,html", "", "width=200,height=100");
</script>
~~~
* close(): 关闭浏览器窗口(浏览器兼容性比较差)
~~~
window.close();
~~~
* setInterval("要调用的函数或要执行的代码串",毫秒数) 1秒=1000毫秒 按照指定的周期(以毫秒计)来调用函数或计算表达式。(一般用作定时器)
* setTimeout("js代码",毫秒数) setTimeout() 只执行 code 一次。如果要多次调用,请使用 setInterval() 或者让 code 自身再次调用 setTimeout()。
* clearInterval(): 清除setInterval设置的定时器 clearInterval() 方法的参数必须是由 setInterval() 返回的 ID 值。
* clearTimeout() : 清除setTimeout设置的定时器 clearInterval() 方法的参数必须是由 setInterval() 返回的 ID 值。
~~~
<!--实现钟表 实时显示当前时间 setInterval(),clearInterval()-->
<html>
<body>
<input type="text" id="clock" size="35" />
<button onclick="int=window.clearInterval(int)">Stop interval</button>
</body>
<script type="text/javascript">
//表示每三秒,执行一次alert方法
//window.setInterval("alert('123');",3000);
var int=self.setInterval("clock()",50)
function clock(){
var t=new Date()
document.getElementById("clock").value=t
}
</script>
</html>
~~~

~~~
var id1 = setInterval("alert('123');",3000);//通过setInterval会有一个返回值
clearInterval(id1); // clearInterval() 方法的参数必须是由 setInterval() 返回的 ID 值。
~~~
~~~
//表示四秒之后执行js代码,但只会执行一次。 setTimeout
window.setTimeout("alert('abc');",4000); //四秒后弹出显示abc ,只此一次
~~~
~~~
var id2 = setTimeout("alert('abc');",4000);
clearTimeout(id2); //四秒后不弹出显示abc 。 //clearInterval() 方法的参数必须是由 setInterval() 返回的 ID 值。
~~~
********八、js的dom对象********
* dom:document object model: 文档对象模型
* 文档:超文本文档(超文本标记文档) html 、xml
* 对象:提供了属性和方法 (封装了属性和行为的实例,可以直接被调用)
* 模型:使用属性和方法操作超文本标记型文档 (所有的标记型文档都具有一些共性特征的一个体现)
* 用来将标记型文档封装成对象,并将标记型文档中的所有内容(标签、文本、属性)都封装成对象。
* 封装成对象的目的是为了更方便的操作这些文档及其文档中的所有内容。因为对象包含属性和行为。
* DOM:将文档解析成内存中的树状结构.通过树状结构对文档进行 添加节点 删除节点 修改节点 查找节点
* 标记型文档包含标签、属性、标签中封装的数据。只要是标记型文档,DOM这种技术都可以对其进行操作。
* 可以使用js里面的dom里面提供的对象,使用这些对象的属性和方法,对标记型文档进行操作
* 想要对标记型文档进行操作
* 首先需要 对标记型文档里面的所有内容封装成对象(需要把html里面的标签、属性、文本内容都封装成对象)
* 还需要解析标记型文档(画图分析,如何使用dom解析html)
* * 解析过程:根据html的层级结构,在内存中分配一个树形结构,需要把html中的每部分封装成对象
* document对象:整个文档
* element对象:元素对象
* 属性对象
* 文本对象
* Node节点对象:这个对象是这些对象的父对象 如果在对象里面找不到想要的方法,这个时候到Node对象里面去找

NODE接口的特性和方法:

* DOM模型有三种:(发展历史)
* DOM level 1:将html文档封装成对象。
* DOM level 2:在level 1的基础上添加新的功能,例如:对于事件和css样式的支持。
* DOM level 3:支持xml1.0的一些新特性。
* DHTML:是很多技术的简称
* 动态的HTML,他不是一门语言,是多项技术综合体的简称: 包括html, css, dom, javascript
* 这四种语言的职责:
* Html:负责提供标签,封装数据,这样便于操作数据。
* Css:负责提供样式,对标签中的数据进行样式定义。
* Dom:负责将标签及其内容解析,封装成对象,对象中具有属性和行为。
* Javascript:负责提供程序设计语言,对页面中的对象进行逻辑操作。专门指的是js的语法语句(第一部分ECMAScript)
* BOM 和 HTML DOM关系图

********九、document对象********
* (Document对象表示整个的文档) 每个载入浏览器的html文档都会成为Document对象
* 常用属性
* all\[\] 提供对文档中多有html元素的访问 FF不支持
* forms\[\]返回对文档中所有Form对象引用
* body 提供对元素的直接访问
* 常用方法
* write(): 向文档写HTML表达式 或javascript代码
~~~
var str = "abc";
document.write(str); //向页面输出变量(值)
document.write("<hr/>"); //向页面输出html代码
~~~
* createElement():创建一个元素标签
* createTextNode():创建一个文本节点
* node对象.appendChild(node);
~~~
<html>
<!-- 需求:在末尾添加节点:创建一个<li>深圳</li> 将其放在ul中 -->
<body>
<ul id="city">
<li>北京</li>
<li>上海</li>
<li>广州</li>
</ul>
</body>
<script type="text/javascript">
//1.创建一个li标签
var liElement = document.createElement("li");
//2.创建一个文本节点 深圳
var textElement = document.createTextNode("深圳");
//3.将文本内容添加到li标签中
liElement.appendChild(textElement);
//4.将li添加到ul中
var city = document.getElementById("city");
city.appendChild(liElement);
</script>
</html>
~~~
* getElementById(): 通过id得到元素(标签)
~~~
<html>
<body>
<input type="text" id="nameid" name="aaa" />
</body>
<script type="text/javascript">
var input1 = document.getElementById("nameid");
alert(input1.name); //aaa 得到input里面的name值 (标签对象.名称)
input1.value = "bbbbb"; //向input里面设置一个值value
</script>
</html>
~~~
* getElementsByName(): 通过标签的name的属性值得到元素(标签),返回的是一个集合(数组)
~~~
<html>
<body>
<input type="text" id="nameid1" name="aaa" value="第一个"/>
<input type="text" id="nameid2" name="aaa" value="第二个"/>
<input type="text" id="nameid3" name="aaa" value="第三个"/>
</body>
<script type="text/javascript">
var inputs = document.getElementsByName("aaa"); ////传递的参数是 标签里面的name的值
//遍历数组
for(var i=0; i<inputs.length; i++){
var input1 = inputs[i]; //每次循环得到input对象,赋值到input1里面
alert(input1.value); //得到每个input标签里面的value值
}
</script>
</html>
~~~
* getElementsByTagName(): 通过标签名称得到元素,返回的是一个集合(数组)
~~~
<html>
<body>
<input type="text" id="nameid1" name="aaa" value="第一个"/>
<input type="text" id="nameid2" name="aaa" value="第二个"/>
<input type="text" id="nameid3" name="aaa" value="第三个"/>
</body>
<script type="text/javascript">
var inputs = document.getElementsByTagName("input"); //传递的参数,是标签名称
//遍历数组,得到每个input标签
for(var m=0;m<inputs.length;m++) {
//得到每个input标签
var input1 = inputs[m];
//得到value值
alert(input1.value);
}
</script>
</html>
~~~
* 注意的地方:当 只有一个标签,这个标签只能使用name获取到,这个时候,使用getElementsByName返回的是一个数组。 但是现在只有一个元素,这个时候不需要遍历,而是可以直接通过数组的下标获取到值
~~~
<body>
<input type="text" name="aaa" value="bbb"/>
</body>
<script type="text/javascript">
var input1 = document.getElementsByName("aaa")[0]; //此处使用数组下标[0],得到的input1为第一个元素 (使用getElementsByTagName时同样如此)
alert(input1.value);
</script>
~~~
- 空白目录
- 常用功能
- PHP中常用的header头部定义
- 压缩包下载1
- 压缩包下载2
- 文件下载
- php常用加密函数总结
- url请求参数加解密
- PHP操作大全
- 指定月份的第某个月
- PHP 数组和字符串互相转换实现方法
- php字符串截取的简单方法
- php 根据子分类循环获取其父级分类
- PHP文件操作功能函数大全
- PHP常用到的功能函数
- 自定义php常用函数110个
- 自定义PHP常用功能函数
- 开发中常用自定义小功能函数
- PHP判断远程文件是否存在
- PHP写文件函数
- PHP生成GUID的函数
- PHP常用正则表达式汇总
- php字符串压缩
- PHP无限分组
- PHP简单 对象(object) 与 数组(array) 的转换
- PHP数组常用函数
- PHP调式测试函数
- PHP常用字符串的操作函数
- mysql 常用内置函数
- PHP通用请求函数CURL封装
- 裁剪图片PHP代码
- PDO操作MYSQL封装类
- 10个实用的PHP代码片段
- 获取访问者IP地址
- PHP实现发红包程序
- PHP把文本转换成图片
- curl重写php file_get_contents
- PHP生成一个随机字符串
- PHP读文件和写文件
- PHP根据key 给二维数组分组
- php中curl模拟post提交多维数组
- 33个超级有用必须要收藏的PHP代码样例
- PHP防XSS 防SQL注入的代码
- php常用数组array函数实例总结
- 用PHP遍历目录下的全部文件
- GBK2UTF8
- php函数类库
- 一、php一些常用的校验
- 1.1、校验是否为空(null/空串)1
- 1.2、校验是否为纯数字1
- 1.3、校验是否为纯数字(正则)1
- 1.4、检验手机号1
- 1.5、校验邮箱格式1
- 1.6、检查密码长度是否符合规定1
- 二、手机类型访问判断
- 三、字符集文件转换
- 3.1、utf8转gbk
- 3.2、gbk转utf8
- 3.3、繁体转简体
- 3.4、简体转繁体
- 3.5、unicode转utf8
- 3.6、utf8转unicode
- 3.7、Ascii转拼音
- 3.8、gbk转拼音
- 3.9、数组 utf8转gbk
- 3.10、数组 gbk转utf8
- 3.11、json 处理gbk转码utf-8问题( json_encode转换数组,值为null)
- 3.12、Unicode解码
- 四、文档目录操作
- 4.1、转化 \ 为 /
- 4.2、创建目录
- 4.3、拷贝目录及下面所有文件
- 4.4、转换目录下面的所有文件编码格式
- 4.5、列出目录下所有文件
- 4.6、设置目录下面的所有文件的访问和修改时间
- 4.7、目录列表
- 4.8、删除目录及目录下面的所有文件
- 4.9、取得文件扩展
- 4.10、查询字符是否存在于某字符串
- 4.11、获取文件目录列表
- 4.12、删除一个路径下的所有文件夹和文件的方法
- 4.13、文件下载
- 五、session与cookie
- 5.1、设置session
- 5.2、读取session
- 5.3、清除session
- 六、CURL操作
- 6.1、发起get请求
- 6.2、发起post请求
- 6.3、curl获取跳转后的网址的url
- 6.4、curl判断远程图片是否加防盗链
- 6.5、curl获取301页面的内容
- 6.6、curl判断文件是否存在(404)
- 6.7、php的curl封装类
- 七、日期、时间与字节转换
- 7.1、转换字节数为其他单位(Gb、Mb等)
- 7.2、时间转换(将秒转换为时间)
- 7.3、将秒转换成 天-时分秒
- 7.4、时间转换(将时分秒转换为秒)
- 7.5、计算两个时间相差的天
- 7.6、获取文件大小并格式化
- 7.7、返回13位时间戳
- 7.8、返回与当前时间的差距,如1分钟前,2小时前,5月前等
- 7.8、PHP中DateTime的常用方法
- 八、对象、数组、字符串、转义等
- 8.1、将数组转换为对象
- 8.2、将对象转换为数组
- 8.3、将字符串转换为数组
- 8.4、将数组转换为字符串
- 8.5、将文本格式成适合js输出的字符串
- 8.6、返回经addslashes(转义)处理过的字符串或数组
- 8.7、返回经stripslashes(删除反斜杠)处理过的字符串或数组
- 8.8、返回经htmlspecialchars(字符转html)处理过的字符串或数组
- 8.9、安全过滤函数
- 8.10、xss过滤函数
- 8.11、过滤ASCII码从0-28的控制字符
- 8.12、格式化文本域内容
- 8.13、将文本格式成适合js输出的字符串
- 8.14、转义 javascript 代码标记
- 8.15、数组转码
- 8.16、php用逗号格式化数字
- 8.17、数组去重
- 8.18、字符串去重
- 8.19、数组排序
- 九、加密扩展
- 9.1、简单的字符串加密、解密函数
- 9.2、简单的加密解密类
- 9.3、简单对称加密算法2
- 9.4、常用对称加密算法(DES/AES)类
- 9.5、3des加密解密类-三重数据加密算法
- 十、随机数、获取请求ip等
- 10.1、产生随机字符串
- 10.2、获取请求ip
- 10.3、生成一定范围内的随机数字
- 10.4、生成不重复的随机数
- 10.5、生成一定数量的随机数,并且不重复
- 10.6、生成32位随机数
- 10.7、生成9位随机数字(可以做qq用)
- 十一、其他
- 11.1、php对html页面压缩函数
- 11.2、构建层级(树状)数组、
- 11.3、获取内容中的图片
- 11.4、生成sql语句,如果传入$in_cloumn 生成格式为 IN('a', 'b', 'c')
- 11.5、打印各种类型的数据,调试程序时使用。
- 11.6、URL重定向
- 11.7、替换html代码里的所有图片的url,新增url
- 11.8、去除html里的p标签
- 11.9、去除字符串中所有html代码(格式化代码html)
- 11.10、将number_format的输出转换为php数字
- 11.7、内容里批量替换图片的url地址为自己的地址
- 十二、类库
- 1、php 5.6.3PHP封装的数据库模型Model类完整示例【基于PDO】
- 2、Curl类库
- 3、php PDO数据库类库
- 4、获取网站title
- 字符串配置转数组
- 数组助手类1
- 获取随机字符串
- 获取头像存储路径
- 单位转换函数
- 获取字符串长度
- 获取中文字符拼音首字母
- 获取当前页面URL地址
- 获取n天前的时间戳
- 获取n天前0点的时间戳
- 获取ip地址所在的区域
- 邮箱验证
- PHP常用函数总结(160多个)
- PHP判断输入数据是否合法常用的类
- 无限极分类
- php ajax实现分页功能
- 代码
- html
- sendAjax.js
- data.js
- page.js
- page.css
- php基础
- 字符串
- 字符串1
- 字符串常用函数
- 数组
- 数组简介
- 数组的定义
- 数组的操作
- 1 数组的计算
- 2 for循环遍历索引数组
- 3 foreach遍历关联数组
- 4 list、each函数遍历数组
- 5 常用操作数组函数
- 数组的常用函数
- 时间
- PHP的日期和时间
- 1 获取时期时间信息函数
- 2 日期验证函数
- 3 获取本地化时间戳函数
- 4 程序执行时间检测
- 文件操作
- 文件处理系统
- 1 读取文件
- 2 创建和修改文件内容
- 3 创建临时文件
- 4 移动、拷贝和删除文件
- 5 检测文件属性函数
- 6 文件常用函数和常量
- 7 文件锁处机制
- 8 目录处理函数
- 9 文件权限设置
- 10文件路径函数
- 11 小小文件留言本
- 12 修改配置文件的实例
- 流程控制
- 流程控制结构
- if条件结构流程
- 1 if语句
- 2 嵌套if...else...elseif结构
- 3 if语句多种嵌套
- 分支结构switch语句的使用
- 循环语句的使用
- 1 while循环
- 2 do...while循环的区别
- 3 for循环控制语句
- 4 goto语法
- 5 declare 语法
- 函数
- PHP函数
- 自定义函数
- 自定义函数高级调用
- 1 回调函数
- 2 变量函数
- 3 匿名函数
- 4 内部函数
- 5 变量作用域
- 6 参数的引用
- 7 递归函数
- 8 静态变量
- 使用系统内置函数
- 文件包含函数
- 数学常用函数
- 正则
- PHP正则表达式
- 1 正则表达示的定界符
- 2 正则表达示中的原子
- 3 正则表示中的元字符
- 4 正则达达示中的模式修正符
- 5 写正则的诀窍和常用正则
- 6 用正则写一个UBB文本编辑器
- 常用正则
- 错误处理
- 1 禁止显示错误
- 2 错误报告级别
- 3 错误记录日志
- 4 自定义错误处理函数
- 错误及异常处理机制、错误日志
- 过滤器
- 表达式
- PHP基本语法
- PHP基本语法(一)
- PHP基本语法(二)
- GD库图像处理
- 文件上传和下载
- PHP文件上传
- 1 文件上传需要注意php.ini文件
- 2 文件上传的步骤
- 3 文件上传表单注意事项
- 4 按照数组和步骤完成文件上传
- 5 多文件上传
- 6 文件上传进度处理
- PHP图像处理
- 1 学习前的准备工作
- 2 用图片处理函数画一张图
- 3 生成验证码
- 4 图像缩放和裁剪技术
- 5 图片水印处理
- 常量和变量
- 1 用常量限制用户跳过某些文件
- .2 可变变量
- 3 外部变量
- 4 环境变量
- 5 变量引用
- PHP表达式与运算符
- 1 算术运算
- 2 赋值运算
- 3 自加、自减运算
- 4 比较运算
- 5 逻辑运算
- 6 位运算
- 7 运算符优先级
- 8 三元运算符和其它运算符
- 会话管理和控制
- 1 Cookie概述
- 2PHP中的Cookie
- 3 session概述
- 4 PHP中使用session
- 5 SESSION应用实例
- 会话技术(cookie session)
- 会话技术 session场景使用介绍!
- PHP.in中session和cookie的配置说明
- 通过cURL来做小偷程序
- 1 curl的使用步骤
- 2 自定义get方法抓取网页
- 3 使用post发送数据
- PHP基础数据类型及运算符介绍
- 数据类型
- 1 整型就是整数
- 2 布尔就是易经的知识
- 3 字符串
- 4 浮点型
- 5 重要:if和else语法
- 6 NULL类型
- 7对象以后会学
- 8 数组会有单纯的一个章节
- 9 资源类型
- 10 眼前了解回调类型即可
- 11 查看和判断数据类型
- 12 数据类型的自动转换和强制转换
- PHP版本
- php自动加载
- xml的介绍
- openssl的介绍
- php文件管理
- 数据库Mysql
- 数据库之MySQL(概述)
- PHP数据库编程
- 数据库编程(2)
- SQL常见的可优化点
- Mysql设计与优化专题
- mysql的最佳索引攻略
- 详解慢查询
- ER图,数据建模与数据字典
- 数据中设计中的范式与反范式
- 字段类型与合理的选择字段类型
- 表的垂直拆分和水平拆分
- 21分钟 MySQL 入门教程
- 一、MySQL的相关概念介绍
- 二、Windows下MySQL的配置
- 三、MySQL脚本的基本组成
- 四、MySQL中的数据类型
- 五、使用MySQL数据库
- 六、操作MySQL数据库
- 七、创建后的修改
- 八、附录
- 3天入门MySQL
- 前言1
- 01. 数据库的用途和概念
- 02. 娱乐化讲解表关系
- 03. mysql 数据库安装
- 04. 数据语句操作类型
- 05. 连接数据库
- 06. 数据库结构定义语句
- 6.2 数据表操作
- 6.1 数据库操作
- 6.3 数据字段操作
- 07. 类型、字符集、引擎和索引
- 7.1 数据类型
- 7.2 字符集
- 7.3 表引擎
- 7.4 索引
- 08. 增删改查
- 12.8.1 插入记录
- 12.8.2 查询记录
- 12.8.3 多表联合查询
- 12.8.4 更新记录
- 12.8.5 删除记录
- 09. DCL语句
- 10. 常用工具简介
- 附录1 . 学习MySQL常用的英文单词
- MySQL 超新手入门
- (1) 重新开始
- (2) 数据库概论和 MySQL 安装
- (3) SELECT 基础查询
- (4) 运算式和函数
- (5) JOIN 和 UNION 查询
- (6) CRUD 和资料维护
- (7) 字符集和数据库
- (8) 存储引擎和数据类型
- (9) 表格和索引
- (10) 子查询
- (11) 视图
- (12) 预处理语句
- (13) 存储过程入门
- (14) 存储过程的变量和流程
- (15) 存储过程进阶
- (16) 触发器
- (17) 资料库资讯
- (18) 错误处理和查询
- (19) 导入和导出数据
- (20) 性能
- php常用类
- 面向对象
- 面向对象(OOP)编程完全教程
- 1.什么是面向对象
- 2.什么是类,什么是对象,类和对象这间的关系
- 3.什么是面向对象编程呢
- 4.如何抽象出一个类
- 5.如何实例化对象
- 6.如何去使用对象中的成员
- 7.特殊的引用this的使用
- 8.构造方法__construct()与析构方法__destruct()
- 9.封装性(var与public,protected,private的关系)
- 10.__set(),__get(),__isset(),__unset()四个方法的应用
- 11.类的继承
- 12.重载新的方法(parent::)
- 13.访问类型(public,protected,private)
- 14.final关键字的应用
- 15.static和const关键字的使用(self::)
- 16.__toString()方法
- 17.克隆对象__clone()方法
- 18.__call()处理调用错误
- 19.抽象方法和抽象类(abstract)
- 20.PHP5接口技术(interface)
- 21.多态的应用
- 22.把对象串行化serialize()方法,__sleep()方法,__wakeup()方法
- 23.自动加载类 __autoload()函数
- PHPer进阶
- 单例模式
- 工厂方法模式
- 适配器模式
- 建造者模式(通过选择mysql,mongo数据库链接类型做说明)
- 委托模式
- 对象基础实践
- 深入了解面向对象高级特性
- 抽象类和接口类的实际作用
- PHP解决问题进化论(整理笔记)
- PHP7新特性整理介绍篇
- php-fpm 与 Nginx优化总结
- Centos+Nginx+PHP7.0编译安装(和PHP5.6老版本共存)
- PHP7:Mongodb API使用
- PHP之include/require深入了解
- PHP内核了解:生命周期及运行模式
- 面向对象总结
- 基础概念
- 什么是类
- 什么是对象
- 静态属性
- 三大特征
- 封装
- 继承
- 多态
- 9个常用的魔术方法
- __construct
- __destruct
- __call
- __get
- __set
- __sleep
- __toString
- __clone
- __autoload
- 抽象类
- 对象接口
- 面向对象设计模式
- 前言
- (一),单例模式
- (二),Builder模式
- (三),原型模式
- (四),工厂方法模式
- (五),策略模式
- (六),状态模式
- (七),观察者模式
- (八),责任链模式
- (九),适配器模式
- (十),代理模式
- (十一),装饰模式
- (十二),外观模式
- (十三),解释器模式
- PHP开发第一步,PHP5.6 + MySQL5.5 + Apache2.4环境搭建
- 面向对象1
- 类和对象
- 面向对象高级
- php编程总结
- PHP学习笔记
- MySQL学习笔记
- php基础知识
- javascript
- javascript DOM总结
- JavaScript (JS) 函数补充 (含arguments、eval()、四种调用模式)
- JavaScript (JS) 面向对象编程 浅析 (含对象、函数原型链、闭包解析)
- JavaScript (JS)基础:BOM 浅析 (含window对象相关基本方法、属性解析)
- JavaScript (JS)基础:DOM 浅析 (含数组Array、字符串String基本方法解析)
- JavaScript (JS)基础:ECMAScript 浅析 (含Math基本方法解析)
- js功能函数
- 一、js一些常用的校验
- 1.1、校验是否为空(null/空串)
- 1.2、校验是否为纯数字
- 1.3、校验是否为纯数字(正则)
- 1.4、检验手机号
- 1.5、验证座机号
- 1.6、校验ip
- 1.7、检验url地址
- 1.8、检验身份证
- 1.9、检验邮箱
- 1.10、检验日期
- 1.11、检验金额
- 1.12、检验否是汉字
- 1.13、校验数字的表达式
- 1.14、校验字符的表达式
- 1.15、特殊需求表达式
- 1.16、检测密码强度
- 二、手机类型判断
- 三、返回字符串长度,汉子计数为2
- 四、获取url中的参数
- 五、js 绑定事件 适用于任何浏览器的元素绑定
- 六、获得当前浏览器JS的版本
- 七、获取当前点击事件的Object对象
- 八、字符串截取方法
- 九、JS 弹出新窗口全屏
- 十、全选/全不选
- 十一、js 判断浏览器
- 十二、JS判断两个日期大小
- 十三、移除事件
- 十四、回车提交
- 十五、JS 执行计时器
- 十六、JS 写Cookie
- 十七、JS 读Cookie
- 十八、Ajax 请求
- 十九、JS StringBuilder 用法
- 二十、JS 加载到顶部LoadJS
- 二十一、清空 LoadJS 加载到顶部的js引用
- 二十二、JS 替换非法字符
- 二十三、按Ctrl + Entert 直接提交表单
- 二十四、获取当前时间
- 二十五、Js 去掉空格方法
- 二十六、js 动态移除 head 里的 js 引用
- 二十七、整个URL 点击事件 加在URL里的onclick里
- 二十八、判断浏览器使用的是哪个 JS 版本
- 二十九、加入收藏夹
- 三十、动态加载 CSS 样式文件
- 三十一、返回脚本内容
- 三十二、清除脚本内容
- 三十三、返回按ID检索的元素对象
- 三十四、显示元素 待验证
- 三十五、与insertBefore方法(已存在)对应的insertAfter方法
- 三十六、光标停在文字的后面,文本框获得焦点时调用
- 三十七、检验URL链接是否有效
- 三十八、格式化CSS样式代码
- 三十九、压缩CSS样式代码
- 四十、 获取当前路径
- 四十一、ip 转 整型
- 四十二、整型解析为IP地址
- 四十三、删除cookies
- 四十四、判断是否以某个字符串结束
- 四十五、判断是否以某个字符串开头
- 四十六、根据样式名称检索元素对象
- 四十七、 获取移动设备初始化大小
- 四十八、 获取移动设备最大化大小
- 四十九、获取移动设备屏幕宽度
- 五十、获取页面scrollLeft
- 六十、获取页面宽度
- 六十一、获取页面scrollTop
- 六十二、获取页面可视高度
- 六十三、判断数组元素是否重复
- 六十四、生成随机数
- 六十五、数组去重
- 六十六、深度拷贝对象
- 六十七、全部替换replaceAll
- 六十八、阻止冒泡
- 六十九、返回顶部
- 七十、jsonp跨域请求
- 七十一、到某一个时间的倒计时
- 七十二、清除对象中值为空的属性
- 七十三、获取文件后缀名的方法
- 七十四、判断一个对象是不是数组类型
- 七十五、冒泡排序
- 七十六、实现一个最简单的模板引擎
- 七十七、数组最大值最小值
- 七十八、数组求和,平均值
- 七十九、从数组中随机获取元素
- 八十、返回对应元素在数组中的下标
- 八十一、返回数组(字符串)一个元素出现的次数
- 八十二、得到n1-n2下标的数组,即返回数组下标arr[n1]到数组arr[n2]的值
- 八十三、筛选数组,这里所做的就只是删除相应的数组
- 八十四、去除字符串空格
- 八十五、字母大小写切换
- 八十六、字符串循环复制,前面的要循环的字符串,后面的要循环的次数
- 八十七、字符串替换,这里的要替换的字符串必须是连续的
- 八十九、将时间戳转换成日期格式
- 九十、检验字符串是否超过某个值,超出出现省略号
- 九十一、随机码,这里的参数count必须是 2 ~ 36 之间的整数
- 九十二、查找字符串中某字符出现的次数
- 九十三、JS插入排序
- 九十四、获取前num天的日期
- 九十五、js实时计算rem,宽度大于1920px时1rem=100px
- 九十六、原生JS获取鼠标XY轴的值
- 九十七、转成XML对象
- 九十八、Js身份证验证函数
- 九十九、格式化数字串
- 一百、原生Ajax 请求
- 一百零一、两条直角边算角度
- 一百零二、禁止readonly和disabled的input退格键返回上一页
- 一百零三、生成随机字母字符串
- 一百零四、float偏移处理
- 一百零五、根据月份获取起止时间戳
- 一百零六、工具函数对象书写例子,可自己扩展
- 一百零七、js字符串压缩算法与解压
- 一百零八、指定数组元素排序(正序倒序)
- 一百零九、js所有的内置方法
- JavaScript 常用函数总结
- js常用函数整理
- JavaScript基础
- javaScript基础&DOM(一)
- javaScript基础&DOM(二)
- JavaScript语法基础1
- javascript数组对象
- javascript字符串函数
- jquery、javascript实现(get、post两种方式)跨域解决方法
- php MVC原理
- php基础知识(语法与原理)
- PHP编程经验
- 第一章 代码风格
- 第二章 代码注释
- 第三章 目录结构
- 第四章 文件管理
- 第五章 代码整理
- 第六章 路径和路由
- 第七章 实用表格
- 第八章 实用开发软件
- 第九章 技术提升心得
- 第十章 实用插件搭配
- 第十一章 常用设计模式
- PHP编码规范文档
- PHP加快执行效率的写法规范
- VUE避坑指南
- 从零开始学Vue
- Vue-cli
- PHP工具类
- 数组助手类
- 通用助手类
- 时间助手类
- 图像
- 拼音助手类
- 字符串助手类
- 验证助手类
- 时间类封装
- 数据库链式调用封装
- curl 封装 / 发送文件 / 远程下载到服务器
- php Captcha 驗證碼類
- php 替换敏感字符串
- php返回数据格式化类
- php XML文件解释类
- php CSS Update Class
- PHPMailer - PHP email transport class
- PHP 遍历文件夹及文件类及处理类
- 自动登入google play下载app report
- php click captcha 验证码类
- php 获取页面中的指定内容类
- php 支持断点续传的文件下载类
- php 缩略图生成类,支持imagemagick及gd库两种处理
- php 根据url自动生成缩略图
- php 过滤html标记属性类
- php HTTP请求类,支持GET,POST,Multipart/form-data
- php Cookies 操作类
- php 密码生成类
- php main 与 iframe 相互通讯类(同域/跨域)
- php 根据url自动生成缩略图,并处理高并发问题
- php Timer 页面运行时间监测类
- php 双向队列类
- php 导出CSV抽象类
- php zip文件内容比较类
- php 获取/设置用户访问页面语言类
- php 获取Youtube某个User所有Video信息
- php 字符编码转换类,支持ANSI、Unicode、Unicode big endian、UTF-8、UTF-8+Bom 互相转换
- php 版本处理类
- TP5
- 验证器
- 内置规则
- tp5数据库操作
- 数据添加或更新
- 静态增删改查 / 关联操作
- 日志操作
- 路由
- taglib-自制标签
- migrations 数据库迁移
- TP3.2
- 数据库操作
- 发送邮箱
- Tp6
- Redis
- 字符串 / 列表 / Hash / Set / Zet / 基数统计算法
- 队列 /订阅发布 php实例
- 事务 / bitmap 位图 / 地理位置
- 备份与恢复 / 性能测试
- 设置密码 / 模糊查询
- 性能优化
- php+redis实现高并发模拟下单、秒杀、抢购操作
- Redis 的简单介绍
- Redis 最常见的问题
- 扩展thinkphp5的redis类方法
- php for redis
- 前言11
- 字符串11
- 集合
- 有序集合
- 列表
- 哈希
- key操作
- Redis 基础教程
- 简介
- 递增
- 过期
- 列表1
- 集合1
- 可排序集合
- 哈希表
- Redis学习文档
- 序言
- 简介1
- Window 下安装
- 执行
- Linux 下安装
- 数据类型1
- String
- Hash
- List
- Set
- zset
- 区别和详解
- 命令
- Keys
- flushall
- del
- ping
- 设置密码
- 实例
- PHP+Redis 实例【一】点赞 + 热度
- Thinkphp+Redis
- 数据队列
- 字符串111
- 列表11
- 集合11
- 哈希1
- 有序集合1
- 添加redis函数助手
- 基础知识
- Redis的7个应用场景
- 深入解析Redis中常见的应用场景
- MongoDB和Redis的区别
- 相关书籍
- 函数整理
- redis知识总结
- redis学习文档
- 常用命令
- 运维常用命令
- 通用操作相关命令
- 字符串相关命令
- 链表list相关命令
- 集合set相关命令
- 有序集合相关指令
- 哈希hash
- 事务
- 订阅和发布
- rdb快照持久化
- aof日志持久化
- redis集群 主从配置
- sentinel监视
- key的设计
- Redis实践技巧
- 前言111
- 第1章 keys键操作
- 第2章 string类型
- 第3章 list类型
- 第4章 set类型
- 第5章 sort set排序类型
- 第6章 hash类型
- 第7章 redis备份
- 第8章 主从复制
- 第9章 设置密码
- 第10章 事务
- 第11章 php操作redis
- Redis常见7种使用场景(PHP实战)
- redis
- jQuery学习总结
- jquery总结2
- Git
- php微信接口开发
- php微信接口开发(卷一)
- 开发心得
- 申请微信测试号
- 打通服务器与微信之间的通信
- 接受微信发送的信息
- 回复微信发送的信息
- 微信回复单图文消息
- 微信回复多图文消息
- curl用法小测试
- 获取access_token
- 获取微信的media_id
- 微信回复图片消息
- 关注自动回复
- 微信生成自定义菜单
- 【实战】后台管理自定义菜单
- 1.页面数据提交并展示
- 2.组装一、二级菜单
- 3.完成简略自定义菜单
- 【实战】thinkphp框架开发微信接口
- 1.相关东西下载地址
- 2.配置thinkphp3.2.3
- 3.微信回复文本消息
- 4.微信获取个人基本信息
- php微信接口开发(卷二)
- 网页授权获取用户基本信息
- 1.输出回调地址
- 2.获取用户信息页面
- 3.数据写入数据库
- 用户分组接口的使用
- 1.对上节代码的优化处理
- 2.获取所有用户组
- 3.创建一个分组
- 4.查询指定用户的分组
- 群发消息的接口的使用
- 1.创建新控制器
- 2.预览群发消息接口
- 3.群发消息
- 生成带参数的二维码
- 长连接转短连接
- 微信js-SDK的引入
- 1.获取jsapi_ticket
- 2.判断当前客户端版本是否支持指定JS接口
- 图像接口的使用
- 扫一扫二维码接口
- php微信接口开发(卷三)
- 微信公众号
- 1.前提条件
- 2.微信公众平台需要做的设置
- 微信支付商户平台
- 1.操作证书
- 2.配置密钥
- 3.配置支付授权目录
- 公众号支付(Jsapi支付)
- 1.SDK与demo下载
- 2.测试DEMO
- 3.将支付接口更为真实公众号信息
- 微信商城
- 1.tp3+bootstrap使用实战
- 2.图片上传实战
- 3.商城后台实战
- 4.购买商城实战
- 5.下订单后使用微信支付
- 小程序基础
- 简介12
- 接入指南
- 开发者工具的使用
- 代码审核与发布
- 小程序申请微信认证
- 小程序申请微信支付
- 小程序绑定微信开放平台帐号
- app.json配置
- 配置demo
- pages
- window
- tabBar
- networkTimeout
- debug
- page.json
- API
- 发起网络请求
- 网络请求提交表单
- 引入
- WeUI
