2011-12-29 3 views
-4

일반 컴퓨터에서 jQuery 모바일 및 일부 다른 코드를 모바일 장치에 표시하고 jQuery 및 기타 코드를 표시 할 수있는 코드가 있습니다. jQuery 모바일 전에 jQuery 코드를 넣는 것이 더 낫다고 들었습니다. 그래서 if/else 문을 전환하여 일반 컴퓨터 코드를 먼저 처리하는 방법을 알고 싶습니다. 이 질문에 대한 내 코드의 수정 된 버전을 보는 것이 가장 좋습니다.if/else 교환 필요합니다.

<?php $mobile_browser = '0'; if (preg_match('/(up.browser|up.link|mmp|symbian|smartphone|midp|wap|phone|android)/i', strtolower($_SERVER['HTTP_USER_AGENT']))) { $mobile_browser++; } if ((strpos(strtolower($_SERVER['HTTP_ACCEPT']),'application/vnd.wap.xhtml+xml') > 0) or ((isset($_SERVER['HTTP_X_WAP_PROFILE']) or isset($_SERVER['HTTP_PROFILE'])))) { $mobile_browser++; } $mobile_ua = strtolower(substr($_SERVER['HTTP_USER_AGENT'], 0, 4)); $mobile_agents = array('w3c ','acs-','alav','alca','amoi','audi','avan','benq','bird','blac', 'blaz','brew','cell','cldc','cmd-','dang','doco','eric','hipt','inno', 'ipaq','java','jigs','kddi','keji','leno','lg-c','lg-d','lg-g','lge-', 'maui','maxo','midp','mits','mmef','mobi','mot-','moto','mwbp','nec-', 'newt','noki','oper','palm','pana','pant','phil','play','port','prox', 'qwap','sage','sams','sany','sch-','sec-','send','seri','sgh-','shar', 'sie-','siem','smal','smar','sony','sph-','symb','t-mo','teli','tim-', 'tosh','tsm-','upg1','upsi','vk-v','voda','wap-','wapa','wapi','wapp', 'wapr','webc','winw','winw','xda ','xda-'); if (in_array($mobile_ua,$mobile_agents)) { $mobile_browser++; } if (strpos(strtolower($_SERVER['ALL_HTTP']),'OperaMini') > 0) { $mobile_browser++; } if (strpos(strtolower($_SERVER['HTTP_USER_AGENT']),'windows') > 0) { $mobile_browser = 0; } if ($mobile_browser > 0) { ?> 
    <link href="http://www.luvbid.com/css/mobilestyle.css" type="text/css" rel="stylesheet" /> 
    <meta name="viewport" content="width=device-width, initial-scale=1"> 
    <link rel="stylesheet" href="http://code.jquery.com/mobile/1.0/jquery.mobile-1.0.min.css" /> 
    <script type="text/javascript" src="http://code.jquery.com/jquery-1.6.4.min.js"></script> 
    <script type="text/javascript" src="http://code.jquery.com/mobile/1.0/jquery.mobile-1.0.min.js"></script> 
    <script> 
     $('div').bind('pageinit', function() { 
      $(this).find('a').bind('click', function(e) { 
       e.preventDefault(); 
       //add your custom ajax call here 
      }); 
     }); 

    </script> 
    <? } else { ?> 
    <link href="http://www.luvbid.com/css/style.css" type="text/css" rel="stylesheet" /> 
    <script src="http://cdn.jquerytools.org/1.2.6/jquery.tools.min.js"></script> 
    <link type="text/css" rel="stylesheet" href="http://ajax.googleapis.com/ajax/libs/jqueryui/1.8.6/themes/smoothness/jquery-ui.css" /> 
    <script src="https://ajax.googleapis.com/ajax/libs/jquery/1.6.4/jquery.min.js"></script> 
    <script src="https://ajax.googleapis.com/ajax/libs/jqueryui/1.8.6/jquery-ui.min.js"></script> 
    <script src="js/jquery.alerts.js"></script> 
    <script src="http://cdn.jquerytools.org/1.2.6/form/jquery.tools.min.js"></script> 
    <? } ?> 
+1

이 계산 편집으로 ... : ( – Prescott

+0

그게 전부 다 읽기가 어렵습니다. 대부분의 사람들은 그것을 가지고 있습니다. – Prescott

+2

당신은 3 가지 질문을 가지고 있습니다. 긍정적이거나 0 번으로 아무 것도없고, 같은 주제를 따르는 의견이 있습니다. 당신은 당신의 문제에 대해 _Solution_을 요구하고 있습니다. 실제로 SO는 당신을 돕기 위해 여기에 있습니다. 문제를 수정하는 와드. 의견이 말하는 내용과 리팩터링 질문을 메모 해 두십시오. – Bojangles

답변

1

변경 코드의 첫 번째 줄의 마지막 부분은

if ($mobile_browser <= 0) 

대신

if ($mobile_browser > 0) 

대답 당신은 사업에 있어야합니다. 그냥 모든 포함 및 이동 기억뿐만 아니라 재료 :

0
if ($mobile_browser > 0)... 

if ($mobile_browser <= 0)... 

된다 그러나 이것은 정말 후에 만 ​​출력 될 모바일 버전을 참조하는 코드로 당신을 도울 것입니다 표현이 평가되었다. 이 문제는 서버 측에서 발생하며 페이지가 클라이언트 관점에서 어떤 성능을 발휘하는지와 아무 관련이 없습니다. 떨어져 깨진 첫 번째 줄에있는 모든 문에 현재

0

, 그것은 다음과 같습니다

<?php $mobile_browser = '0'; 
if (preg_match('/(up.browser|up.link|mmp|symbian|smartphone|midp|wap|phone|android)/i', strtolower($_SERVER['HTTP_USER_AGENT']))) { $mobile_browser++; } 
if ((strpos(strtolower($_SERVER['HTTP_ACCEPT']),'application/vnd.wap.xhtml+xml') > 0) or ((isset($_SERVER['HTTP_X_WAP_PROFILE']) or isset($_SERVER['HTTP_PROFILE'])))) { $mobile_browser++; } 
$mobile_ua = strtolower(substr($_SERVER['HTTP_USER_AGENT'], 0, 4)); 
$mobile_agents = array('w3c ','acs-','alav','alca','amoi','audi','avan','benq','bird','blac', 'blaz','brew','cell','cldc','cmd-','dang','doco','eric','hipt','inno', 'ipaq','java','jigs','kddi','keji','leno','lg-c','lg-d','lg-g','lge-', 'maui','maxo','midp','mits','mmef','mobi','mot-','moto','mwbp','nec-', 'newt','noki','oper','palm','pana','pant','phil','play','port','prox', 'qwap','sage','sams','sany','sch-','sec-','send','seri','sgh-','shar', 'sie-','siem','smal','smar','sony','sph-','symb','t-mo','teli','tim-', 'tosh','tsm-','upg1','upsi','vk-v','voda','wap-','wapa','wapi','wapp', 'wapr','webc','winw','winw','xda ','xda-'); if (in_array($mobile_ua,$mobile_agents)) { $mobile_browser++; } 
if (strpos(strtolower($_SERVER['ALL_HTTP']),'OperaMini') > 0) { $mobile_browser++; } 
if (strpos(strtolower($_SERVER['HTTP_USER_AGENT']),'windows') > 0) { $mobile_browser = 0; } 
if ($mobile_browser > 0) { ?> 

변경 최종 경우 이에 대한 문 :

if ($mobile_browser == 0)