如何做网站模版

如何利用Thinkphp框架开发移动端接口详解

方案一:给原生APP提供api接口使用TP框架时 放在common文件夹下文件名就叫function.php123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180     <?php/*** Created by zhangkx* Email: zkx520tnhb@163.com* Date: 2015/8/1* Time: 23:15*/  /****** api开发辅助函数 *******/  /*** @param null $msg 返回正确的提示信息* @param flag success CURD 操作成功* @param array $data 具体返回信息* Function descript: 返回带参数,标志信息,提示信息的json 数组**/function returnApiSuccess($msg = null,$data = array()){$result = array('flag' => 'Success','msg' => $msg,'data' =>$data);print json_encode($result);}  /*** @param null $msg 返回具体错误的提示信息* @param flag success CURD 操作失败* Function descript:返回标志信息 ‘Error',和提示信息的json 数组*/function returnApiError($msg = null){$result = array('flag' => 'Error','msg' => $msg,);print json_encode($result);}  /*** @param null $msg 返回具体错误的提示信息* @param flag success CURD 操作失败* Function descript:返回标志信息 ‘Error',和提示信息,当前系统繁忙,请稍后重试;*/function returnApiErrorExample(){$result = array('flag' => 'Error','msg' => '当前系统繁忙,请稍后重试!',);print json_encode($result);}  /*** @param null $data* @return array|mixed|null* Function descript: 过滤post提交的参数;**/  function checkDataPost($data = null){if(!empty($data)){$data = explode(',',$data);foreach($data as $k=>$v){if((!isset($_POST[$k]))||(empty($_POST[$k]))){if($_POST[$k]!==0 && $_POST[$k]!=='0'){returnApiError($k.'值为空!');}}}unset($data);$data = I('post.');unset($data['_URL_'],$data['token']);return $data;}}  /*** @param null $data* @return array|mixed|null* Function descript: 过滤get提交的参数;**/function checkDataGet($data = null){if(!empty($data)){$data = explode(',',$data);foreach($data as $k=>$v){if((!isset($_GET[$k]))||(empty($_GET[$k]))){if($_GET[$k]!==0 && $_GET[$k]!=='0'){returnApiError($k.'值为空!');}}}unset($data);$data = I('get.');unset($data['_URL_'],$data['token']);return $data;}}     查询单个果品详细信息         /*** 发布模块** 获取信息单个果品详细信息**/public function getMyReleaseInfo(){//检查是否通过post方法得到数据checkdataPost('id');$where['id'] = $_POST['id'];$field[] = 'id,fruit_name,high_price,low_price,address,size,weight,fruit_pic,remark';$releaseInfo = $this->release_obj->findRelease($where,$field);$releaseInfo['remark'] = mb_substr($releaseInfo['remark'],0,49,'utf-8').'...';//多张图地址按逗号截取字符串,截取后如果存在空数组则需要过滤掉$releaseInfo['fruit_pic'] = array_filter(explode(',', $releaseInfo['fruit_pic']));$fruit_pic = $releaseInfo['fruit_pic'];unset($releaseInfo['fruit_pic']);//为图片添加存储路径foreach($fruit_pic as $k=>$v ){$releaseInfo['fruit_pic'][] = 'http://'.$_SERVER['HTTP_HOST'].'/Uploads/Release/'.$v;}if($releaseInfo){returnApiSuccess('',$releaseInfo);}else{returnApiError( '什么也没查到(+_+)!');}}     findRelease() 方法的model         /*** 查询一条数据*/public function findRelease($where,$field){if($where['status'] == '' || empty($where['status'])){$where['status'] = array('neq','9');}$result = $this->where($where)->field($field)->find();return $result;}     app端接收到的数据(解码json之后)         {"flag": "success","message": "","responseList": {"id": "2","fruit_name": "苹果","high_price": "8.0","low_price": "5.0","address": "天津小白楼水果市场","size": "2.0","weight": "2.0","remark": "急需...","fruit_pic": ["http://fruit.txunda.com/Uploads/Release/201508/55599e7514815.png","http://fruit.txunda.com/Uploads/Release/201508/554f2dc45b526.jpg"]}}     app端接收到的数据(原生json串)代码如下: {"flag":"success","message":"","responseList":{"id":"2","fruit_name":"\u82f9\u679c","high_price":"8.0","low_price":"5.0","address":"\u5929\u6d25\u5c0f\u767d\u697c\u6c34\u679c\u5e02\u573a","size":"2.0","weight":"2.0","remark":"\u6025\u9700...","fruit_pic":["http:\/\/fruit.txunda.com\/Uploads\/Release\/201508\/55599e7514815.png","http:\/\/fruit.txunda.com\/Uploads\/Release\/201508\/554f2dc45b526.jpg"]}}方案二:另外我们还可以通过ThinkPHP实现移动端访问自动切换主题模板,这样也可以做到移动端访问ThinkPHP的模板主题机制,如果只是在PC,只要需修改 DEFAULT_THEME (新版模板主题默认是空,表示不启用模板主题功能)配置项就可以方便的实现多模板主题切换。但对于移动端与PC端,也许你会设计完全不同的主题风格,且针对不同的来路提供不同的渲染方式,其中一种比较流行的方法是“响应式设计”,但就本人经历而言,要实现完全的“响应式设计”并不是那么容易,且解决兼容问题也是个难题,假设是大型站点,比如:淘宝、百度、拍拍这些,响应式设计肯定是满足不了需求的,而是需要针对手机访问用户提供单独的手机网站。ThinkPHP 完全能够实现,而且非常的简单。与TPM的智能模版切换引擎相同,只要对来路进行判断处理就行了。一、将 ismobile() 加入到{项目/Common/common.php}    1234567891011121314151617181920212223242526272829303132function ismobile() {// 如果有HTTP_X_WAP_PROFILE则一定是移动设备if (isset ($_SERVER['HTTP_X_WAP_PROFILE']))return true;  //此条摘自TPM智能切换模板引擎,适合TPM开发if(isset ($_SERVER['HTTP_CLIENT']) &&'PhoneClient'==$_SERVER['HTTP_CLIENT'])return true;//如果via信息含有wap则一定是移动设备,部分服务商会屏蔽该信息if (isset ($_SERVER['HTTP_VIA']))//找不到为flase,否则为truereturn stristr($_SERVER['HTTP_VIA'], 'wap') ? true : false;//判断手机发送的客户端标志,兼容性有待提高if (isset ($_SERVER['HTTP_USER_AGENT'])) {$clientkeywords = array('nokia','sony','ericsson','mot','samsung','htc','sgh','lg','sharp','sie-','philips','panasonic','alcatel','lenovo','iphone','ipod','blackberry','meizu','android','netfront','symbian','ucweb','windowsce','palm','operamini','operamobi','openwave','nexusone','cldc','midp','wap','mobile');//从HTTP_USER_AGENT中查找手机浏览器的关键字if (preg_match("/(" . implode('|', $clientkeywords) . ")/i", strtolower($_SERVER['HTTP_USER_AGENT']))) {return true;}}//协议法,因为有可能不准确,放到最后判断if (isset ($_SERVER['HTTP_ACCEPT'])) {// 如果只支持wml并且不支持html那一定是移动设备// 如果支持wml和html但是wml在html之前则是移动设备if ((strpos($_SERVER['HTTP_ACCEPT'], 'vnd.wap.wml') !== false) && (strpos($_SERVER['HTTP_ACCEPT'], 'text/html') === false || (strpos($_SERVER['HTTP_ACCEPT'], 'vnd.wap.wml') < strpos($_SERVER['HTTP_ACCEPT'], 'text/html')))) {return true;}}return false;}二、在{项目/Lib/}创建一个 CommonAction.php,假设你的项目已公共控制器,则无需创建,直接加在里面就行了。 12345678910Class CommonAction extends Action{Public function _initialize(){//移动设备浏览,则切换模板if (ismobile()) {//设置默认默认主题为 MobileC('DEFAULT_THEME','Mobile');}//............你的代码.......}}   

公众号这种格式的页面是怎么做的?点开一个链接里面都是文章,还有分

微信公众号页面模板功能需要通才能使用微信页面模版功能给公众号创建行业网页功能插件暂通原创声明功能微信公众号申请通原创声明功能通比较难需要邀请通主申请给家推荐简单 使用第三功能实现比我用 网站蚂蚁Page页面模板限制微信公众号类型任何微信公众号都使用需认证需通支付需通原创 功能强特别简单

如何修改用织梦做的网站的主页模板

\DedeAMPZ\WebRoot\Default\templets\default,找到你安装的根目录,然后按照我给你的路径,找到index.htm,这个是主页,如果你对HTML和css熟悉,你应该打开就看得懂了,里面凡是带dede的,说明都是织梦的调用标签,你可以不用理会 我直接修改模板里面的html和css代码就可以了对吗?那我怎么查看修改后的效果呢? 如果是在本地调试的,直接输入127.0.0.1,就可能看到效果

网页制作中如何使用PSD模版

其实标准的网制作完成的工作实际是:psd to html,一般情况下,我们会拿到美工的psd,这时候不同的人会有不同的做法: 1.打开fireworks将图片切割导出为html。 2.直接在dreamweaver之类的工具去拖拉布局,导入相关的图片,flash资源。 3.先在ps中完成切图后,在文本编辑器中看着效果图一步步的制作。 以上是大多被采用的方法,但都不好: 第一种方法最为不好,这样的代码根本不具维护性和可读性。 第二种方法也不好,代码难免会有冗余,做出来的东西基本需要排查一遍。 第三种方法也不好,因为你需要看效果图一点点的拼,也就是说写html标签的时候,你在不断的假设这块要怎么去显示。 正确的做法是: 1.拿到psd后,先不要做别的,直接在文本编辑器中将网页的框架写出来,不要假设这块将来css要去怎么渲染,完全自然化的标签,不加任何的css。 2.写完之后在各个浏览器运行之后确保大体定位都没有问题。 3.书写总体css,这里的css只负责大块的定位及样式。 4.切出需要的图片资源,在写好的框架中一点点的去构造,不断的调试,最终为成品。 5.最后,为自己的代码添加注释,在css,html中都要合适的为自己的代码添加注释。 要想做出能灵活切换皮肤,让css主导表现,还有很多要注意的地方,但大体的流程就是这样的,当然我们一开始不能直接就做到先写html,但起码要有这个意识,循序渐进。。。谢谢热心会员"linxz"提供实际经验,我贴上来供大家参考:PSD出网站从两个大点考虑一、一个独立的页面1、分析这个页面,先在脑袋中或者草稿纸上描绘大概的结构2、根据设计稿的的情况,分析背景图的分布、ICO图的分布等3、切割相应的图片,导出、合并图片4、在编辑器中写整体结构XHTML代码,包括页面中出现的所有元素的结构5、编写CSS样式中的整体以及模块代码6、细节调整7、收工,浏览器验证是否正确二、由多个页面组成的小站点或者大站点1、浏览所有设计稿,统一规划站点模块、图片、文件分布2、开始第一点的操作,但规划站点的内容分布很重要整体考虑点:图片的合并,减少请求量结构的合理性,语义化样式的简洁,便于后期维护多为后期的维护以及程序开发着想,如何简单实现效果 参考资料: http://www.wzsky.net/html/Website/Experience/107671.html

网页制作中如何使用PSD模版

其实标准的网制作完成的工作实际是:psd to html,一般情况下,我们会拿到美工的psd,这时候不同的人会有不同的做法: 1.打开fireworks将图片切割导出为html。 2.直接在dreamweaver之类的工具去拖拉布局,导入相关的图片,flash资源。 3.先在ps中完成切图后,在文本编辑器中看着效果图一步步的制作。 以上是大多被采用的方法,但都不好: 第一种方法最为不好,这样的代码根本不具维护性和可读性。 第二种方法也不好,代码难免会有冗余,做出来的东西基本需要排查一遍。 第三种方法也不好,因为你需要看效果图一点点的拼,也就是说写html标签的时候,你在不断的假设这块要怎么去显示。 正确的做法是: 1.拿到psd后,先不要做别的,直接在文本编辑器中将网页的框架写出来,不要假设这块将来css要去怎么渲染,完全自然化的标签,不加任何的css。 2.写完之后在各个浏览器运行之后确保大体定位都没有问题。 3.书写总体css,这里的css只负责大块的定位及样式。 4.切出需要的图片资源,在写好的框架中一点点的去构造,不断的调试,最终为成品。 5.最后,为自己的代码添加注释,在css,html中都要合适的为自己的代码添加注释。 要想做出能灵活切换皮肤,让css主导表现,还有很多要注意的地方,但大体的流程就是这样的,当然我们一开始不能直接就做到先写html,但起码要有这个意识,循序渐进。。。谢谢热心会员"linxz"提供实际经验,我贴上来供大家参考:PSD出网站从两个大点考虑一、一个独立的页面1、分析这个页面,先在脑袋中或者草稿纸上描绘大概的结构2、根据设计稿的的情况,分析背景图的分布、ICO图的分布等3、切割相应的图片,导出、合并图片4、在编辑器中写整体结构XHTML代码,包括页面中出现的所有元素的结构5、编写CSS样式中的整体以及模块代码6、细节调整7、收工,浏览器验证是否正确二、由多个页面组成的小站点或者大站点1、浏览所有设计稿,统一规划站点模块、图片、文件分布2、开始第一点的操作,但规划站点的内容分布很重要整体考虑点:图片的合并,减少请求量结构的合理性,语义化样式的简洁,便于后期维护多为后期的维护以及程序开发着想,如何简单实现效果 参考资料: http://www.wzsky.net/html/Website/Experience/107671.html

建站需求填写

采购需求填写

采购需求

采购产品:
联系人:
* 联系电话:
公司名称:
补充说明:
* 验证码:
提交