|
有一天做做mysql突然發(fā)現(xiàn)原來mysql功能這么強(qiáng)大,可以直接計(jì)算字符串。。。哈哈 這下可就高興了。
代碼還超級簡單 就做了一個ajax的計(jì)算器
有式子錯誤提示 還可以時時顯示輸入的式子
有興趣的朋友可以看看 更多的功能可以自己去開發(fā)
演示地址:http://www.jianlila.com/jsq.php
jquer.js自己去下載
jsq1.php
復(fù)制代碼 代碼如下:
<?php
//鏈接數(shù)據(jù)庫的
$db=mysql_connect("localhost","root","123");
header("Content-Type:text/html;charset=GB2312");
$str=iconv('utf-8','gbk',trim($_POST['t_ask']));
$str=str_replace(" ","",str_replace("/r/n","",$str));
$str=str_replace("(","(",$str);
$str=str_replace(")",")",$str);
/*三角函數(shù)替換*/
$str=preg_replace("/sin/((.*)/)/is","sin(/${1}*pi()/180)",$str);//替換sin
$str=preg_replace("/cos/((.*)/)/is","cos(/${1}*pi()/180)",$str);//替換cos
$str=preg_replace("/tan/((.*)/)/is","tan(/${1}*pi()/180)",$str);//替換tan
$str=preg_replace("/cot/((.*)/)/is","1/tan(/${1}*pi()/180)",$str);//替換余切
$str=preg_replace("/asin/((.*)/)/is","asin(/${1}/pi()*180)*180/pi()",$str);//反正弦
$str=preg_replace("/acos/((.*)/)/is","acos(/${1}/pi()*180)*180/pi()",$str);//反余弦
$str=preg_replace("/atan/((.*)/)/is","atan(/${1}/pi()*180)*180/pi()",$str);//替換反正切
$sql="select ".$str ;
$res=mysql_query($sql,$db) or die('<font color=red>你輸入的式子有錯誤</font>');
$rs=mysql_fetch_array($res);
echo $rs[0];
?>
jsq.php
復(fù)制代碼 代碼如下:
<html>
<head>
<title>手寫輸入計(jì)算器</title>
<meta name="keywords" content="在線計(jì)算器,輸入式子直接計(jì)算,手寫計(jì)算器" />
<meta name="description" content="在線計(jì)算器,手寫輸入計(jì)算器,輸入式子直接計(jì)算" />
<script src="jquery.js" language="Javascript"></script>
<script language="Javascript">
$(function(){
$("#t_ask").keyup(function(){
$.post(
"jsq1.php",
{
t_ask : $("#t_ask").val()
},function(data,textStatus)
{
$("#res").html(data);
}
);
});
});
</script>
</head>
<body>
<table width="800" border="0" align="center" cellpadding="0" cellspacing="0">
<tr>
<td align="center" height="40"><h2>手寫輸入計(jì)算器</h2></td>
</tr>
</table>
<table width="800" border="0" align="center" cellpadding="0" cellspacing="0">
<tr>
<td height="34" align="center">在這里你可以手寫式子計(jì)算哦,還不快試試! <a >返回首頁</a></td>
</tr>
</table>
<form method="post">
<table width="800" border="0" align="center" cellpadding="0" cellspacing="0">
<tr>
<td width="27%" align="right">計(jì)算式子:</td>
<td width="73%"><textarea name="t_ask" cols="60" rows="6" id="t_ask"></textarea></td>
</tr>
<tr>
<td height="23" align="right">=</td>
<td><div id="res"></div></td>
</tr>
<tr>
<td height="31" align="right"></td>
<td><input type="button" name="tj" id="tj" value="按鈕" />
<input type="reset" name="qc" id="qc" value="重置" /></td>
</tr>
</table>
<table width="800" border="0" align="center" cellpadding="0" cellspacing="0">
<tr>
<td><p>說明:<br />
三角函數(shù):
<p>sin(60)正弦 cos(60)余弦 tan(60)正切 cot(60)余切
<p>asin(0.5)反正弦 acos(0.5)
反余弦 atan(0.5)反正切
<p>abs(-1)=1絕對值 ceil(0.1)=1進(jìn)一
<p>指數(shù)對數(shù)
<p>exp(float arg)// 計(jì)算 <strong>e</strong>(自然對數(shù)的底)的指數(shù)
<p>log(10,100)=2//自然對數(shù) pow(2,4)=16 指數(shù) sqrt(4)=2平方根
<p><br />
</td>
</tr>
</table>
</form>
</body>
</html>
php技術(shù):利用php+mysql來做一個功能強(qiáng)大的在線計(jì)算器,轉(zhuǎn)載需保留來源!
鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請第一時間聯(lián)系我們修改或刪除,多謝。