php中分页程序之基于留言板详解

 更新时间:2016年11月25日 17:10  点击:1941
文章是重点是讲php中的分页原理,同时我们是利用一个实现来讲解如何在php中实现分页,这个就是基于自己写的留方板程序了,有需要的朋友可以参考一下,很适合于初学者哦。

分页的关键问题其实在于Mysql的一个关键字limite这个关键字后边跟的两个数字,第一个是需要记录的开始行数,第二个数字是从这个开始行数后取得几行记录——这一点大家不要误以为是从第几行开始到第几行结束,相差很远的。

看看我们index.php的第19行:

 代码如下 复制代码

$recordSql = $sql. ” LIMIT “.$page*$pagesize.”,”.$pagesize;

其中变量$page的判断在程序的第8行和第9行得到的:

 代码如下 复制代码

if(isset($_GET['page'])&&$_GET['page']!=”) $page=$_GET['page'];
else $page=0;

当然大家也看到了$_GET['page']变量这个下文会说到。

变量$pagesize我们在第7行自己定义的,也就是每页显示多少条记录,我们定义的是10条。当变量$page=0的时候我们语句最终会是这样的:

 代码如下 复制代码
$recordSql = "SELECT a . * , b.name, b.email, b.qq, c.revert_time, c.revert
  FROM post a
  LEFT JOIN revert c ON ( a.id = c.post_id ) , guest b
  WHERE a.guest_id = b.id
  ORDER BY a.id DESC
  " LIMIT 0,10";

就是从0条记录开始取得10个记录结果——这个是包括第0条记录的;
当$page=1的时候呢?可想而知了——这个时候$page*$pagesize=10,当然是从……不说了,再说就罗嗦了。

还有需要说的是,为什么我们要在取得总行数之后才加上这个limit呢,很简单嘛,如果我们在取得结果记录数的时候就加上这个limit,我们总行数永远不会大于10,因为加上之后他最多返回的记录数就是10啊兄弟。——这个显然不符合实际情况。所以我们在执行了:

 代码如下 复制代码
mysql_num_rows(mysql_query($sql));

取得总记录数,之后才加上limit关键字的。

好了我们已经取得了总记录数,设置了每页显示的记录数10,现在我们需要的就只有总页数了,这个小学的问题我就不说了吧?当然是总记录数除以每页显示的数就是总页数了——当然也有除不尽的时候,例如总记录数11每页显示10个,我们需要分几页呢?当然是两页呢,怎么才能让11/10=2呢?——显然是错误的,但是实际生活就这样并不是完美的数学。使用ceil函数啊,这个上一章也说过了,不说了。

看看我们现在有什么了啊:

 代码如下 复制代码
总记录数,$numRecord = mysql_num_rows(mysql_query($sql));
总页数,$totalpage = ceil($numRecord/$pagesize);

我们什么都不缺了,就差如何显示“上一页下一页”了,很简单,两个判断就搞定了,看index.php的159-163行:

第160行:

 代码如下 复制代码
if($page>0) echo "<a href=index.php?page=".($page-1).">上一页|</a>" ;

如果变量$page>0的话,也就是当前的页码大于0说明有上一页,那么就显示“上一页”的链接,这个链接里面的$page需要减一,例如当前页是2,那么上一页当然是1了是不是,当我们点击上一页的时候,随着这个链接将会把page=1传递过去,这种依靠链接传递变量的方式就是get方法。 这就回到了程序8行9行进行处理了。

在161行,我们做的判断是,如果当前页数小于总记录数-1——因为我们的页码是从0开始的,所以总记录数要减一进行判断才符合实际。如果这个判断成立,说明还有下一页,下一页的时候$page当然要加一了。

好了整个分页就是这样了,只要记住,如何取得总记录数,如何为sql语句加上limit关键字,如何判断显示上下页,一切都ok了

完整的代码

 代码如下 复制代码

$pagesize = 10;//每一页显示多少留言记录
if(isset($_GET['page'])&&$_GET['page']!='') $page=$_GET['page'];
else $page=0;

$sql = "SELECT a . * , b.name, b.email, b.qq, c.revert_time, c.revert
  FROM post a
  LEFT JOIN revert c ON ( a.id = c.post_id ) , guest b
  WHERE a.guest_id = b.id
  ORDER BY a.id DESC";
$numRecord = mysql_num_rows(mysql_query($sql));
$totalpage = ceil($numRecord/$pagesize);

$recordSql = $sql. " LIMIT ".$page*$pagesize.",".$pagesize;
$result = mysql_query($recordSql);

<table width="800" border="0" align="center" bgcolor="#fefefe">
<?php
while($rs=mysql_fetch_object($result)){
?>
  <tr>
    <td class="tdhx">留言人:<?php echo $rs->name?> |Email:<?php echo $rs->email?>|QQ:<?php echo $rs->qq?>|留言时间:<?php echo date("Y-m-d H:i:s",$rs->post_time+8*3600)?></td>
  </tr>
  <?php
  if(isset($_SESSION['login'])&&$_SESSION['login']){
  ?>
    <tr>
    <td class="tdhx"><a href="revert.php?id=<?php echo $rs->id?>">回复</a> | <a href="delete.php?id=<?php echo $rs->id?>">删除</a></td>
  </tr>
  <?php
  }
  ?>
  <tr>
    <td>留言内容:<?php echo nl2br(htmlspecialchars($rs->post))?><br/>
    <font color="Red">
    回复内容:<?php echo nl2br(htmlspecialchars($rs->revert))?>[<?php if($rs->revert_time!="") echo date("Y-m-d H:i:s",$rs->revert_time+8*3600)?> ]
    </font>
   
    </td>
  </tr>
  <tr><td height="3px"  bgcolor="##FF6600"></td></tr>
<?php
}
?>
</table>
<table width="800" border="0" align="center" bgcolor="#B1C3D9">
  <tr>
    <td >
<?php
if($page>0) echo "<a href='index.php?page=".($page-1)."'>上一页|</a>" ;
if($page<$totalpage-1) echo "<a href='index.php?page=".($page+1)."'>下一页</a>" ;
?></td>
  </tr>
</table>

文章利用了一个简单的实例来实现php从数据库中读取数据详细讲解,有需要的朋友可以看看,这里同时还简单的讲到了安全问题。

先看段代码

 代码如下 复制代码

<?php
session_start();
$con=mysql_connect('localhost','root','root') or die('链接数据库失败!');
mysql_query('set names utf8');
mysql_select_db('GuestBook');

$pagesize = 10;//每一页显示多少留言记录
if(isset($_GET['page'])&&$_GET['page']!='') $page=$_GET['page'];
else $page=0;

$sql = "SELECT a . * , b.name, b.email, b.qq, c.revert_time, c.revert
  FROM post a
  LEFT JOIN revert c ON ( a.id = c.post_id ) , guest b
  WHERE a.guest_id = b.id
  ORDER BY a.id DESC";
$numRecord = mysql_num_rows(mysql_query($sql));
$totalpage = ceil($numRecord/$pagesize);

$recordSql = $sql. " LIMIT ".$page*$pagesize.",".$pagesize;
$result = mysql_query($recordSql);
?>

下面来看看

第一行:我们暂时先不说,留到以后再说,暂时还用不到;
第二行——第五行:大家一定很眼熟吧,是的这里和post.php插入留言信息的时候的过程是一样的,也就不多说了。
7、8、9和19行我们暂时不说,这里是涉及到分页的,我们将会留到下一章详细的说明这个问题,因为分页的过程在web编程过程中几乎是一个必须要使用的功能。

在11-15行我们定义了一个数据库查询语句,在这条语句中我们用了left join …on..语句,关于这个语句的详细用法请参看Mysql手册联合查询部分。。

看第16行,

 代码如下 复制代码

$numRecord = mysql_num_rows(mysql_query($sql));

这个语句中我们用mysql_query($sql)把我们定义的sql语句发给数据库来执行,这个语句执行以后会返回一个记录资源号,我们用外层的mysql_num_rows来取得有多少个匹配的记录——也就是返回的记录总数。

第17行我们用到了ceil函数,这个函数的功能是,进一法取整,也就是说两个数进行除法操作之后只要余数大于零整数部分就加一然后舍去小数部分,所以ceil(1/2)的结果是1,而不是我们通常所见到的0.5。这个对于我们来说很有用——也留到下一章分页的时候再说吧。

第19行,涉及到分页部分。但是这一行值得说的是,在PHP中字符串的相加,也就是字符串的连接。两个字符串相加的操作符是点,看例子:

 代码如下 复制代码

$strFirst=”中国”;
$strTwo=”伟大的国度”;

$strSum = $strFirst.$strTwo;
echo $strSum;

输出的结果正如我们所料到的一样:中国伟大的国度。

第20行:我们发送一个带分页功能的sql语句到数据库执行,并把执行结果赋值给$result;
接着我们看,本页函数的第:128-154行,这个程序的片段功能是循环输出在数据库中查询到的记录。这是我们本章的重点:

看PHP的内置函数mysql_fetch_object()从结果集中取得一行作为对象,关于PHP的对象我们在高级编程栏目中将会详细的说明,我们这里只需要知道这种循环查询记录的方式,需要用 $对象->字段名 来访问就行了,执行起来的时候就是每一次指针下移一次,当遇到没有更多的记录的时候就返回一个false所以我们可以用while循环来读取$result的这个记录集。最终形成了while($rs=mysql_fetch_object($result))这个语句,循环调用mysql_fetch_object函数并且把每次返回的对象赋值给$rs变量,现在哦我们看这个循环的内部,我们可以用$rs->name来取得留言人姓名,用$rs->post_time来访问留言时间。

在显示post_time的时候我们做了一些处理,使用到了date()函数,记得我们存储留言的时候用到了time()函数,这个函数返回的是一个时间戳,就是从1970年的第一秒起到现在已经经过的秒数(格林尼治时间)。而date函数就是把这个秒数翻译为我们所需要的时间格式,返回怎样的字符串需要们在date()函数的第一个参数中制定,该函数的第二个参数如果没有给出,也就是需要翻译成时间格式的秒数没有给出的话,他就会以当前时间来翻译。
Date(“Y年m月d日 H:i:s”),输出结果就是2009年4月26日 11:16:20。

我们在index.php的132行有这样的写法:

 代码如下 复制代码
<?php echo date(”Y-m-d H:i:s”,$rs->post_time+8*3600)?>

我们具体说说这个,我想大家一定会对8*3600这个地方感到奇怪,其实原因很简单。咱们用time()函数存储时间的时候用的是格林尼治时间,这个时间和我们的时间相差刚好八个小时,每个小时3600秒,我们处在东方比西方的时间快所以要加上的。记住我们用的是北京时间——处在东八时区哦,这个是常识!关于这一点还有一个做法,这将会在专门阐述PHP的日期函数的文章里详细说明。

144和146行都用了两个函数htmlspcialchars和nl2br,其中htmlspcialchars这个函数是为了避免用户输入的脚本代码(html和javascript)被执行而必须的,这个函数很重要。如果没有这个函数用户输入的js代码和html代码都会被作为页面程序的一部分被执行,这一点我们在《关于PHP代码安全性建议》一文中已经说过,不在赘述。
nl2br这个函数的作用是讲数据中的n换行转换成html的换行<br/>以便于页面表现。在我们输入留言信息的时候,用的<textarea></textarea>这个表单,保存信息的时候,换行使用n来表示的所以我们这里需要转换,以保留用户输入信息在显示的时候我输入时段落一致。

本文章利用了php中的二个重要的目录操作函数,来实现遍历目录下的目录以及目录下的文件的实现方法,函数我们详细了介绍了,下面看实例
 代码如下 复制代码

<?php

function listFiles($path){
$result = array();
foreach(glob($path.'\'."*") as $item){
$result[strtolower($item)] = $item;
if(is_dir($item)){
$result += listFiles($item);
}
}
return $result;
}
$path = 'E:\web\dianle';
foreach(listFiles($path) as $item){
echo $item.'<br />';
}


function listFiles($path){
$result = array();
foreach( scandir($path) as $item ){
if($item != '.' && $item != '..' ){
$item = $path.'\'.$item;
$result[strtolower($item)] = $item;
if(is_dir($item)){
$result += listFiles($item);
}
}
}
return $result;
}
$path = 'E:\web\dianle';
foreach(listFiles($path) as $item){
echo $item.'<br />';
}
?>

 

用到的一个函数

scandir() 函数返回一个数组,其中包含指定路径中的文件和目录。

若成功,则返回一个数组,若失败,则返回 false。如果 directory 不是目录,则返回布尔值 false 并生成一条 E_WARNING 级的错误。

语法

scandir(directory,sort,context)

参数 描述
directory 必需。规定要扫描的目录。
sort 可选。规定排列顺序。默认是 0 (升序)。如果是 1,则为降序。
context 可选。规定目录句柄的环境。context 是可修改目录流的行为的一套选项

 

现在看另一个函数

glob() 函数返回匹配指定模式的文件名或目录。

该函数返回一个包含有匹配文件 / 目录的数组。如果出错返回 false。

语法

glob(pattern,flags)

参数 描述
file 必需。规定检索模式。
size

可选。规定特殊的设定。

  • GLOB_MARK - 在每个返回的项目中加一个斜线
  • GLOB_NOSORT - 按照文件在目录中出现的原始顺序返回(不排序)
  • GLOB_NOCHECK - 如果没有文件匹配则返回用于搜索的模式
  • GLOB_NOESCAPE - 反斜线不转义元字符
  • GLOB_BRACE - 扩充 {a,b,c} 来匹配 'a','b' 或 'c'
  • GLOB_ONLYDIR - 仅返回与模式匹配的目录项
  • GLOB_ERR - 停止并读取错误信息(比如说不可读的目录),默认的情况下忽略所有错误

注释:GLOB_ERR 是 PHP 5.1 添加的

文章兴实例说明$_GET,$_POST,$_REQUEST的各处优点和不足以及它们三个的用法以实例说明,有需要的朋友可以参考一下。

1. $_REQUEST

默认情况下包含了 $_GET,$_POST 和 $_COOKIE 的数组。

 代码如下 复制代码

<?php

$_GET['foo'] = 'a';
$_POST['bar'] = 'b';
var_dump($_GET); // Element 'foo' is string(1) "a"
var_dump($_POST); // Element 'bar' is string(1) "b"
var_dump($_REQUEST); // Does not contain elements 'foo' or 'bar'

?>

注:它的速度比其它的要慢一些

2. $_GET

$_GET 变量用于收集来自 method="get" 的表单中的值。从带有 GET 方法的表单发送的信息,对任何人都是可见的(会显示在浏览器的地址栏),并且对发送的信息量也有限制(最多 100 个字符)。

实例

 代码如下 复制代码

welcome.php?name=Peter&age=37

welcome.php" 文件现在可以通过 $_GET 变量来获取表单数据了(请注意,表单域的名称会自动成为 $_GET 数组中的 ID 键):

 代码如下 复制代码

Welcome <?php echo $_GET["name"]; ?>.<br />
You are <?php echo $_GET["age"]; ?> years old!

注:数据量不能过大最多只能100个字符或2kb

3. $_POST

$_POST 变量是一个数组,内容是由 HTTP POST 方法发送的变量名称和值。

$_POST 变量用于收集来自 method="post" 的表单中的值。从带有 POST 方法的表单发送的信息,对任何人都是不可见的(不会显示在浏览器的地址栏),并且对发送信息的量也没有限制。

 代码如下 复制代码

<form action="welcome.php" method="post">
Enter your name: <input type="text" name="name" />
Enter your age: <input type="text" name="age" />
<input type="submit" />
</form>

selcome.php文件

 代码如下 复制代码

Welcome <?php echo $_POST["name"]; ?>.<br />
You are <?php echo $_POST["age"]; ?> years old!

注:比get要好很多数据处理量大同时大多用于表单。


三区别在于$_REQUEST可以获取$_GET和$_post的数据,但是效率相对于前二者是要慢些,为什么慢我想大家用脚指都能想明白的,这里就留下大家思想吧。

一篇关于php 入门的朋友参考的关于文件和目录的各种操作函数与实例应用,有需要的朋友可以简单的参考一下。

本章可以算是上一章的延续,介绍了除文件实际内容之外的附加信息,包括文件的大小、目录、访问权限等。文件系统中的某些函数只在服务器为特定的系统中时才有效,例如更改符号链接的函数symlink(),设定文件访问权限的函数chmod(),设定目录访问权限的函数umask()等等这些只在Linux系统中有效,在Windows系统中无效。PHP5以后提供的DirectoryIterator类也封装了很多实用的目录方面的操作

 代码如下 复制代码

//------------- 采用DirectoryIterator类迭代目录中的文件 -------------
foreach(new directoryIterator('/usr/local/images') as $file){
 print $file->getPathname()."n";
}

//------------- PHP5之前版本的实现方式 -------------
$d = opendir('/usr/local/images') or die($php_errormsg);
while(false !==($f = readdir($d))){
 print $f."n";
}

closedir($d);文件信息函数
函数名 函数提供什么文件信息?
file_exists() 该文件是否存在
fileatime() 最后访问时间
filectime() 文件inode的最后修改时间
filegroup() 取得文件组(返回整数)
fileinode() 取得文件的信息节点数(返回整数)
filemtime() 取得文件数据块最后被写入的时间(返回Unix时间戳)
fileowner() 取得文件的所有者(返回用户ID)
fileperms() 取得文件的权限
filesize() 取得文件大小的字节数
filetype() 取得文件类型,可能返回 fifo,char,dir,block,link,file 和 unknown
is_dir() 判断给定文件名是否是一个目录
is_executable() 判断给定文件名是否可执行(自PHP5.0.0起可用于Windows)
is_file() 判断给定文件名是否为一个正常的文件
is_link() 判断给定文件名是否为一个符号连接
is_readable() 判断给定文件名是否可读
is_writable() 判断给定文件名是否可写

目录相关函数
函数名 函数提供什么文件信息?
mkdir() 创建一个新目录,第二个参数可用来设置访问权限
rmdir() 删除目录
rename() 重命名一个文件或目录

目录类相关方法
DirectoryIterator类封装了很多与目录相关的方法

方法名 函数提供什么目录信息?
isDir() 判断给定的DirectoryIterator item对象是否是一个目录
isDot() 判断当前的DirectoryIterator item对象是否是‘.’或‘..’
isFile() 判断当前的DirectoryIterator item对象是否是一个有效的文件
isLink() 判断当前的DirectoryIterator item对象是否是一个连接
isReadable() 判断当前的DirectoryIterator item对象是否可读
isWritable() 判断当前的DirectoryIterator item对象是否可写
isExecutable() 判断当前的DirectoryIterator item对象是否可执行
getATime() 获取当前Iterator item最后访问时间
getCTime() 获取当前Iterator item最后修改时间
getMTime() 获取当前Iterator item文件数据块最后被写入的时间
getFilename() 获取当前Iterator item文件名(带扩展名)
getPathname() 获取当前Iterator item路径名
getPath() 获取当前Iterator item路径名和文件名
getGroup() 获取当前Iterator item组ID
getOwner() 获取当前Iterator item拥有者ID
getPerms() 获取当前Iterator item权限
getSize() 获取当前Iterator item文件大小
getType() 获取当前Iterator item类型,可能是file,link or dir
getInode() 获取当前Iterator item的inode节点号

文件时间戳解惑
touch()函数修改文件的更新时间

fileatime()函数返回文件因为读或写被打开的最后时间

filemtime()函数返回文件内容被修改的最后时间

filectime()函数返回文件内容或元数据被修改的最后时间

获取文件信息
通过stat()可以获取一个包含文件相关信息的数组,与此函数类似的是fstat()函数,这个函数以一个文件句柄作为参数(由fopen()或popen()返回),lstat()用来获取符号或文件连接的信息。

数字索引 字符串索引 说明
0 dev 设备号
1 ino 信息节点号
2 mode 保护模式
3 nlink 被连接数目
4 uid 所有者用户ID
5 gid 所在组ID
6 rdev 设备类型,如果是inode设备的话
7 size 文件大小的字节数
8 atime 上次访问的时间(Unix时间戳)
9 mtime 上次修改的时间(Unix时间戳)
10 ctime 上次改变的时间(Unix时间戳)
11 blksize 文件系统IO的块大小
12 blocks 所占据块的数目

修改文件权限
chmod()函数修改文件的权限

chown()函数修改文件的所有者

chgrp()函数修改文件所属组

注意:上述3个函数在Windows系统中无效
获取文件名各部分信息
basename()函数可以取得文件名,dirname()函数可以取得路径名,pathinfo()取得目录名、完整文件名、扩展名、文件名(即不带扩展名)的关联数组,键名分别是[dirname]、[basename]、[extension]、[filename]

常通过dirname(__FILE__)的组合来获取当前目录路径(物理路径,常用在引用其他PHP文件上)

删除文件
用unlink()函数可以删除一个文件,如果删除失败将产生一个E_WARNING错误

提示:PHP5.0.0后此函数也可以用来删除远程文件,如FTP等
复制或移动文件
使用copy(old_dir,new_dir)函数可以复制文件,使用rename(old_dir,new_dir)移动文件,这里的new_dir是可以可以重命名文件名的。

模式匹配文件名列表(模糊查询)
如果希望像命令行那样查询出某个目录中的所有jpg文件(*.jpg),可以使用DirectoryIterator类的FileterIterator子类accept()方法或者glob()函数获取匹配的文件名。

//FileterIterator的实现代码

 代码如下 复制代码

class ImageFilter extends FilterIterator {
    public function accept() {
        return preg_match('@.(gif|jpe?g|png)$@i',$this->current());
    }
}
foreach (new ImageFilter(new DirectoryIterator('/usr/local/images')) as $img) {
    print "

n";
}

//-------------- glob函数的实现代码 ------------

 代码如下 复制代码
foreach (glob('/usr/local/docs/*.txt') as $file) {
   $contents = file_get_contents($file);
   print "$file contains $contentsn";

}递归目录中的文件
如果想获得一个目录及其子目录的文件大小,可以使用RecursiveDirectoryIterator(提供子目录获取的功能)和RecursiveIteratorIterator(平整化)

 代码如下 复制代码

$dir = new RecursiveDirectoryIterator('/usr/local');
$totalSize = 0;
foreach (new RecursiveIteratorIterator($dir) as $file) {
    $totalSize += $file->getSize();
}
print "The total size is $totalSize.n";

[!--infotagslink--]

相关文章

  • php KindEditor文章内分页的实例方法

    我们这里介绍php与KindEditor编辑器使用时如何利用KindEditor编辑器的分页功能实现文章内容分页,KindEditor编辑器在我们点击分页时会插入代码,我们只要以它为分切符,就...2016-11-25
  • C#开发Windows窗体应用程序的简单操作步骤

    这篇文章主要介绍了C#开发Windows窗体应用程序的简单操作步骤,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...2021-04-12
  • 自己动手写的jquery分页控件(非常简单实用)

    最近接了一个项目,其中有需求要用到jquery分页控件,上网也找到了需要分页控件,各种写法各种用法,都是很复杂,最终决定自己动手写一个jquery分页控件,全当是练练手了。写的不好,还请见谅,本分页控件在chrome测试过,其他的兼容性...2015-10-30
  • C++调用C#的DLL程序实现方法

    本文通过例子,讲述了C++调用C#的DLL程序的方法,作出了以下总结,下面就让我们一起来学习吧。...2020-06-25
  • C#使用Process类调用外部exe程序

    本文通过两个示例讲解了一下Process类调用外部应用程序的基本用法,并简单讲解了StartInfo属性,有需要的朋友可以参考一下。...2020-06-25
  • 微信小程序 页面传值详解

    这篇文章主要介绍了微信小程序 页面传值详解的相关资料,需要的朋友可以参考下...2017-03-13
  • jquery实现的伪分页效果代码

    本文实例讲述了jquery实现的伪分页效果代码。分享给大家供大家参考,具体如下:这里介绍的jquery伪分页效果,在火狐下表现完美,IE全系列下有些问题,引入了jQuery1.7.2插件,代码里有丰富的注释,相信对学习jQuery有不小的帮助,期...2015-10-30
  • 使用GruntJS构建Web程序之构建篇

    大概有如下步骤 新建项目Bejs 新建文件package.json 新建文件Gruntfile.js 命令行执行grunt任务 一、新建项目Bejs源码放在src下,该目录有两个js文件,selector.js和ajax.js。编译后代码放在dest,这个grunt会...2014-06-07
  • uniapp微信小程序:key失效的解决方法

    这篇文章主要介绍了uniapp微信小程序:key失效的解决方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2021-01-20
  • vue.js 表格分页ajax 异步加载数据

    Vue.js通过简洁的API提供高效的数据绑定和灵活的组件系统.这篇文章主要介绍了vue.js 表格分页ajax 异步加载数据的相关资料,需要的朋友可以参考下...2016-10-20
  • PHP常用的小程序代码段

    本文实例讲述了PHP常用的小程序代码段。分享给大家供大家参考,具体如下:1.计算两个时间的相差几天$startdate=strtotime("2009-12-09");$enddate=strtotime("2009-12-05");上面的php时间日期函数strtotime已经把字符串...2015-11-24
  • 将c#编写的程序打包成应用程序的实现步骤分享(安装,卸载) 图文

    时常会写用c#一些程序,但如何将他们和photoshop一样的大型软件打成一个压缩包,以便于发布....2020-06-25
  • 微信小程序 网络请求(GET请求)详解

    这篇文章主要介绍了微信小程序 网络请求(GET请求)详解的相关资料,需要的朋友可以参考下...2016-11-22
  • 微信小程序如何获取图片宽度与高度

    这篇文章主要给大家介绍了关于微信小程序如何获取图片宽度与高度的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2021-03-10
  • 微信小程序自定义tabbar组件

    这篇文章主要为大家详细介绍了微信小程序自定义tabbar组件,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...2021-03-14
  • node.js+express留言板功能实现示例

    本文介绍基于nodejs+express+art-template的留言板功能。包含列表界面、添加界面和发送留言功能,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...2021-09-21
  • 微信小程序二维码生成工具 weapp-qrcode详解

    这篇文章主要介绍了微信小程序 二维码生成工具 weapp-qrcode详解,教大家如何在项目中引入weapp-qrcode.js文件,通过实例代码给大家介绍的非常详细,需要的朋友可以参考下...2021-10-23
  • Springboot如何使用mybatis实现拦截SQL分页

    这篇文章主要介绍了Springboot使用mybatis实现拦截SQL分页,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下...2020-06-19
  • PHP 一个完整的分页类(附源码)

    在php中要实现分页比起asp中要简单很多了,我们核心就是直接获取当前页面然后判断每页多少再到数据库中利用limit就可以实现分页查询了,下面我来详细介绍分页类实现程序...2016-11-25
  • Python爬取微信小程序通用方法代码实例详解

    这篇文章主要介绍了Python爬取微信小程序通用方法代码实例详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下...2020-09-29