首页 > 开发 > PHP > 正文

利用PHP和CSS改变网页文字大小

2024-05-04 23:03:33
字体:
来源:转载
供稿:网友

在设计网站的时候,要牢记一点:并不是所有的访问者都是神采奕奕的年轻人,而且他们也不一定完全熟悉web浏览器的各种使用方法。聪明的设计者了解这一点,他们常常将各种特殊的可访问特性融入网站的设计中,这样,即使是年长者或是残疾人士都可以方便舒适地使用网站,而不必花费额外的力气。

文本大小调节器是最有效的可访问特性中的一个,任何网站都可能需要它,简而言之,这是一个用于改变网页文字大小的工具,通常用于将文本变大从而易于阅读,很多浏览器已经自带了这一特色,但是网络浏览器的初学者并不知道如何使用这一功能,因此,网站的设计者经常将更易于使用的按钮放在每个网页上来实现这一功能。

这篇指南将向您介绍如何使用php和css在网页上添加具备这种功能的文本大小调节器,因此,赶快向您的网站添加这一可访问性,这样从年纪大于50岁的用户那里获得赞誉的积分,继续向下读,您将学会使用它的方法。

注意:这篇指南假定您已经安装了apache和php 

它是如何工作的?
在写代码之前,花一些时间来理解文本大小调节器的工作方式是非常有益的。网站中的每个网页都包含一系列控制按钮,他们允许用户选择页面的文字大小:小号、中号和大号,每种字号都对应于一种css样式表,这些样式表保存了用于渲染网页文本大小的规则。
 

当用户做出选择的时候,php将用户选定的字号存储在一个会话变量中,然后重新加载网页,该页面将从会话变量中读取选定的字号,并动态调用相应的样式表以更小的字号或更大的字号来重新渲染网页。

过程
第一步:创建网页
从创建html文档开始,首先完成占位符的内容,列表a是一个例子:
列表a:

text size: small | href="resize.php?s=medium">medium | large

loremipsum dolor sit amet,
consecteturadipisicingelit, sed do eiusmodtemporincididuntutlabore et dolore
magna aliqua. utenim
ad minim veniam, quisnostrud exercitation ullamcolaboris nisi utaliquip ex ea
commodoconsequat.
duisauteirure dolor in reprehenderit in
voluptatevelitessecillumdoloreeufugiatnullapariatur.
excepteursintoccaecatcupidatat non proident, sunt in culpa qui
officiadeseruntmollitanim id estlaborum.

对页面顶部的文字超链接要特别注意,每个超链接都指向了名为resize.php的脚本文件,并通过url get方法将选定的字体大小传递给它。

在您的web服务器目录中以.php的扩展名来保存这个文档,例如,index.php。

第二步:创建样式表
接下来,为每种文字大小创建样式表文件:small.css, medium.css和large.css,这是small.css的文件内容:

body {
font: 10px
}

同样,可以创建medium.css和large.css,分别使用17px和25px,将这些样式表文件和上一步创建的网页保存在同一个目录中。

第三步:创建文本大小的改变机制
正如上文介绍的,网页通过查找预先定义的会话变量可以"知道"加载哪个样式表文件,会话变量是通过脚本文件resize.php来控制的(参见列表b),该文件是在用户点击了网页顶部改变文字大小的按钮时激活的,这是resize.php的内容:
 
列表b
// start session
// import selected size into session
session_start();
$_session['textsize'] = $_get['s'];
header("location: " . $_server['http_referer']);
?>
 
这很简单,当用户选择了一种新的文本大小,resize.php通过get方法来获得字号的值,并将其存储在会话变量$_session['textsize']中,然后将浏览器重新定向到原来打开的哪个页面。
 
当然,这里还缺少一个组件:智能化得让网页自动检测现在用户现在选定的文本大小并加载相应的样式表,为加入这一功能,打开您的网页文件index.php,并将以下语句加入到文件的开头(参见列表c):
 

列表c
// start session
// import variables
session_start();
// set default text size for this page
if (!isset($_session['textsize'])) {
$_session['textsize'] = 'medium';
}
?>
 
you should also add a stylesheet link between the ... elements, as follows:
type="text/css">
 
这是列表d,完整的index.php文件应该是这样的:
列表d:
// start session
// import variables
session_start();
// set default text size for this page
if (!isset($_session['textsize'])) {
$_session['textsize'] = 'medium';
}
?>

type="text/css">

text size: small | href="resize.php?s=medium">medium | large

loremipsum dolor sit amet,
consecteturadipisicingelit, sed do eiusmodtemporincididuntutlabore et dolore
magna aliqua. utenim
ad minim veniam, quisnostrud exercitation ullamcolaboris nisi utaliquip ex ea
commodoconsequat.
duisauteirure dolor in reprehenderit in
voluptatevelitessecillumdoloreeufugiatnullapariatur.
excepteursintoccaecatcupidatat non proident, sunt in culpa qui
officiadeseruntmollitanim id estlaborum.

理解这种工作方式应该很简单了,当载入网页的时候,它恢复当前的会话,并检查$_session['textsize']变量是否与当先选择的字号相符,然后通过元素动态加载相应的样式表,这将导致网页以正确的大小自动重新渲染。

联合使用php和css与传统的方式略有不同,传统方式是使用javascript来动态改变css样式表,相对于javascript方法,php方法的优势在于您不需要依赖客户端对javascript的支持,您也不需担心专门创建针对某个浏览器的工作,也许下一次您坐下来设计网站的时候会发现这种方法很有效,祝编程愉快!


发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表