Javascript 仅在手机/平板电脑上显示隐藏/显示按钮

Javascript 仅在手机/平板电脑上显示隐藏/显示按钮,javascript,jquery,html,css,Javascript,Jquery,Html,Css,我有以下演示: 目前它适用于所有平台,但我更希望显示按钮和隐藏内容仅适用于平板电脑和手机。桌面将自动显示内容并隐藏按钮 有人能解释一下我是怎么做到的吗?我会使用媒体查询还是在Javascript中使用 MyjQuery: $(document).ready(function() { $('.nav-toggle').click(function(){ //get collapse content selector var collapse_content_selector =

我有以下演示:

目前它适用于所有平台,但我更希望显示按钮和隐藏内容仅适用于平板电脑和手机。桌面将自动显示内容并隐藏按钮

有人能解释一下我是怎么做到的吗?我会使用媒体查询还是在Javascript中使用

MyjQuery

$(document).ready(function() {
  $('.nav-toggle').click(function(){
    //get collapse content selector
    var collapse_content_selector = $(this).attr('href');                   

    //make the collapse content to be shown or hide
    var toggle_switch = $(this);
    $(collapse_content_selector).toggle(function(){
      if($(this).css('display')=='none'){
                        //change the button label to be 'Show'
        toggle_switch.html('Show');
      }else{
                        //change the button label to be 'Hide'
        toggle_switch.html('Hide');
      }
    });
  });

}); 

谢谢。

使用这些脚本,您可以检测任何移动浏览器


我认为最短的解决方案是要求使用mobil浏览器,如果用户没有使用mobil浏览器,请执行按钮的
click()
功能,使用这些脚本,您可以检测任何移动浏览器


我认为最短的解决方案是要求使用mobil浏览器,如果用户没有使用mobil浏览器,请执行按钮的
click()
功能。我个人建议不要使用浏览器检测,除非您想专门针对允许您实现的浏览器。根据您的要求,为什么不尝试媒体查询

 .nav-toggle{
   display : none; // display none for everyone
 }

/* Landscape phone to portrait tablet  show the button */
@media (max-width: 767px) {

 .nav-toggle{
   display : block; // or inline-block or inline : which ever is appropriate for you.
 }

}Hmmm您可以尝试的选项很少。我个人建议不要使用浏览器检测,除非您想专门针对允许您实现的浏览器。根据您的要求,为什么不尝试媒体查询

 .nav-toggle{
   display : none; // display none for everyone
 }

/* Landscape phone to portrait tablet  show the button */
@media (max-width: 767px) {

 .nav-toggle{
   display : block; // or inline-block or inline : which ever is appropriate for you.
 }

}

-从这里开始您可以通过检测后端的用户代理在顶层添加一个小类。比如说。如果可以,那么解决方案就相当简单了。您可以使用$('body.mobile.nav toggle')而不是$('.nav toggle')。您可以使用$.browser,但请注意,它在较新版本中已被弃用-从这里开始您可以通过检测后端中的用户代理在顶层添加一个小类。比如说。如果可以,那么解决方案就相当简单了。您可以使用$('body.mobile.nav toggle')而不是$('.nav toggle')。您可以使用$.browser,但请注意,它在较新版本中已被弃用