会员可以在此提问,百战程序员老师有问必答
对大家有帮助的问答会被标记为“推荐”
看完课程过来浏览一下别人提的问题,会帮你学得更全面
截止目前,同学们一共提了 132647个问题

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
  <style>
    *{
      margin: 0;
      padding: 0;
    }
    ul{
      background-color: #eaffea;
      list-style: none;
      font-size: 14px;
      width: 150px;
      display: block;
      position: relative;
      cursor: pointer;
      /*把鼠标变成小手*/
      display: none;
      z-index: 999;
    }
    li{
      padding-left: 20px;
      line-height: 25px;
    }
    li:hover{
      background-color: #fffdef;

    }
  </style>
</head>

<body>
<ul>
  <li>查看网页源代码</li>
  <li>刷新网页(F5)</li>
  <li>离开网页</li>
  <li>跳转到百度</li>
  <li>根据文本框内容搜索</li>
  <li>输入内容搜索</li>
</ul>
<div style="margin: 20px auto;width: 500px;position: relative">
  <span>搜索内容:</span><input type="text" style="width: 300px;">
</div>
<script>
  window.onload=function(){
    var ul=document.querySelector('ul');
    //系统右键菜单禁用事件【contextmenu】
    document.oncontextmenu = function (eve) {
      return false;
    };//return false表示事件禁用

    document.onmouseup=function (eve) {
      // console.log(eve.button);//查看鼠标哪个键被点击 左键0 滑轮1 右键2
      if (eve.button==2){
        ul.style.display='block';
        ul.style.left=event.clientX+'px';
        ul.style.top=event.clientY+'px';
      }else {
        ul.style.display='none';
      }
    }
    //事件委托
    ul.onmousedown=function (eve) {
      // console.log(eve.target.innerHTML);//根据这个来判断是哪一个li
      if (eve.button==2||eve.button==0){
        if (eve.target.innerHTML=='查看网页源代码'){
          alert('我不告诉你!!!');
          ul.style.display='none';
        } else if (eve.target.innerHTML=='刷新网页(F5)'){
          window.location.reload();
        } else if (eve.target.innerHTML=='离开网页'){
          var a=confirm('Do you sure 要离开网页?????');
          // console.log(a);
          if (a){
            window.close();
          } else {
            ul.style.display='none';
          }
        }else if (eve.target.innerHTML=='跳转到百度'){
          window.location.replace('http://www.baidu.com');
        }else if (eve.target.innerHTML=='根据文本框内容搜索'){
          var resukt=document.getSelection().toString();
          window.open('http://www.baidu.com/s?wd='+resukt);
        }
      }
    }
  }

</script>
</body>
</html>

老师,当点击鼠标右键的时候,ul的display属性取值为block或inline-block ,都会使得我本来设置的文本框向下移动;请问老师怎么设置能够使文本框在ul出现时依旧保持之前的位置

1602734274557592.png

image.png

WEB前端全系列/第二阶段:JavaScript编程模块/面向对象编程 481楼

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        *{
            padding: 0;
            margin: 0;
        }
        ul{list-style: none;
        position: absolute;
        display: none;
        min-width: 220px;
            
        }
        li{
            cursor: pointer;
            height: 30px;
            line-height: 30px;
            }
            li:hover{
                background-color: skyblue;
            }
    </style>
</head>
<body>
<ul>
    <li>我想去吃烤鸭</li>
    <li>确认关闭本页面吗?</li>
    <li>去百度搜索页面中选中的内容</li>
    <li>弹出提示框,用户【在提示框中输入内容】然后跳转至百度进行搜索</li>
</ul>
<script>
    var ul=document.querySelector('ul');
    
    document.oncontextmenu = function (eve) {
        return false;  //return false表示事件禁用
    };
    document.onmouseup=function(eve){
        if(eve.button==2){
            ul.style.display='block';
            ul.style.left=eve.clientX+'px';
            ul.style.top=eve.clientY+'px';
       
    }else{
        ul.style.display='none';
    }
   
    }
    ul.onmousedown=function(eve){
        switch (eve.target.innerHTML) {
            case '我想去吃烤鸭':function test1(){
                alert('那就去呗');
            }
                
                break;
        
            default:
                break;
        }
        // if(eve.target.innerHTML=='我想去吃烤鸭'){
        //     alert('去吧');
        }
    
</script>
</body>
</html>

老师为啥我这个mousedown事件用swtich来判断真正触发者,点击了第一个li没反应 但是用if语句判断就可以

WEB前端全系列/第二阶段:JavaScript编程模块/面向对象编程 485楼

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Document节点练习</title>
    <!--<style type="text/css">
        ul{
            list-style: none;margin: 0;padding: 0;
        }
        ul li{
            display: inline-block;width: 100px;height: 30px;line-height: 30px;text-align: center;background-color: #0086b3;
        }
        li a{

        }
        li:hover{
            background-color: #0077aa;
        }
        li a:hover{
            color:red;
        }
    </style>-->
    <style>
        li:hover{background-color: #b3d4fc}
        li a:hover{color:red}
    </style>
</head>
<body>
<!--<ul>
    <li><a href="#">首页</a></li>
    <li><a href="#">新闻</a></li>
    <li><a href="#">军事</a></li>
    <li><a href="#">娱乐</a></li>
</ul>-->
<script>
    var arr=["首页","新闻","军事","娱乐"]
    var ulText=document.createElement('ul');
    var ulText_style= document.createAttribute('style');
    ulText_style.value="list-style: none;margin: 0;padding: 0;";
    ulText.setAttributeNode(ulText_style);
    for(var i=0;i<arr.length;i++){
        var liText=document.createElement('li');
        var liText_style= document.createAttribute('style');
        liText_style.value='display:inline-block;width:100px;height:30px;line-height:30px;\
                             text-align:center;margin-left:5px';
        liText.setAttributeNode(liText_style);

        var aText=document.createElement('a');
        var aText_style= document.createAttribute('style');
        aText_style.value="text-decoration: none;";
        aText.setAttributeNode(aText_style);
        aText.innerHTML=arr[i];
        liText.appendChild(aText);
        ulText.appendChild(liText);
    }
    document.body.appendChild(ulText);
    var arr2 = ['cnode社区也切换到let\'s encrypt了','【深圳】nodeparty 2016.04.09总结','国内nodejs2015','展望nodejs 2016','基础javascript'];
    var ul1 = document.createElement('ul');
    var ul1_style = document.createAttribute('style');
    ul1_style.value = 'height: 30px;list-style: none;padding: 0;margin: 0;';
    ul1.setAttributeNode(ul1_style);
    document.body.appendChild(ul1);
    for (var j =0;j<arr2.length;j++){
        var li1 = document.createElement('li');
        var li1_style = document.createAttribute('style');
        li1_style.value = "height: 30px;line-height: 30px;text-align: left;border-bottom: 1px solid gainsboro;";

        li1.setAttributeNode(li1_style);
        var a1 = document.createElement('a');
        a1.innerHTML = arr2[j];
        li1.appendChild(a1);
        ul1.appendChild(li1);
    }
</script>
</body>
</html>

这样写的话应该是没有什么问题的吧

WEB前端全系列/第二阶段:JavaScript编程模块/DOM模型 487楼

课程分类

百战程序员微信公众号

百战程序员微信小程序

©2014-2025百战汇智(北京)科技有限公司 All Rights Reserved 北京亦庄经济开发区科创十四街 赛蒂国际工业园
网站维护:百战汇智(北京)科技有限公司
京公网安备 11011402011233号    京ICP备18060230号-3    营业执照    经营许可证:京B2-20212637