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

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="initial-scale=1.0, user-scalable=no" />  
    <script type="text/javascript" src="https://api.map.baidu.com/api?v=1.0&&type=webgl&ak=FbonyatSbRvrD6W2ApVIpz5BGT9wE18a"></script>
    <title>百度地图</title>
    <style type="text/css">  
        html{height:100%}    
        body{height:100%;margin:0px;padding:0px}    
        #container{height:500px;width: 700px; border: 1px solid black;}    
    </style> 
</head>
<body>
    <div id="container"></div> 
    <button>加载</button>
    <script>
      var btn=document.querySelector('button');
      btn.onclick=function(){
        var map = new BMapGL.Map("container");
        var point = new BMapGL.Point(116.404, 39.915);//设置中心点 经纬度
        map.centerAndZoom(point, 15);//地图初始化,同时设置地图展示级别 登记1-21  数值越大 
        /*地球模式*/
        // map.centerAndZoom(new BMapGL.Point(118.5, 27.5), 15);  // 初始化地图,设置中心点坐标和地图级别
        // map.enableScrollWheelZoom(true);     //开启鼠标滚轮缩放
        // map.setMapType(BMAP_EARTH_MAP);      // 设置地图类型为地球模式
     //添加控件(系统)
//      map.addControl(new BMapGL.ScaleControl())//比例尺

//      map.addControl(new BMap.OverviewMapControl()); //缩略图
// //      var cityCtrl = new BMapGL.CityListControl();  // 添加城市列表控件
// // map.addControl(cityCtrl);
// map.addControl(new BMapGL.MapTypeControl())

/*自定义插件
自定义摆放位置
anchor:自定义摆放位置
offset:自定义偏移量offset(x,y)
type:控件加载类型
*/
var options={
    anchor:BMAP_ANCHOR_BOTTOM_RIGHT,
    offset:BMAP_ANCHOR_BOTTOM_RIGHT,

}
map.addControl(new BMap.NavigationControl(options));

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

老师 是不是现在百度地图这个api没写出来的控件类型就用不了了  好像这个平移缩放和缩略图控件

image.png

image.png

WEB前端全系列/第九阶段:HTML5新特性模块/(旧)H5新特性 31楼

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>
<body>

    <video src="" height="500px" width="500px" id="video"></video>
    <canvas id="canvas" width="500px" height="500px"></canvas>
    <button class="btn1" onclick="getMedia()">视频</button>
    <button class="btn2" onclick="takePhone()">拍照</button>
    <script>
      /*调用用户设备
      *调用摄像头  移动端会给用户选择 1打开相册 2打开摄像头  pc端直接调用摄像头

      *调用麦克风  直接调用

      *调用方法getUserMedia();
      * Navigator.mediaDevices.getUserMedia(constraints,successCallback,errorCallback)
      
      * constraints 设备类型
      {
      video:true  //s摄像头
      Audio: true //麦克风 
      }
      */
     function getMedia(){
         var video=document.getElementById('video');
         /*
         Navigator.mediaDevices.getUserMedia  该方法返回一个promise对象
         当该方法对象成功返回后 的回掉函数会带有一个MediaStream对象作为其参数
         then()是promise的异步方法,当then()前的所有方法执行完毕后在执行then()方法避免数据没有获取到
          */
         var constraints={
             video:{height:500,width:500},
             audio:true
         }
        var promise=navigator.mediaDevices.getUserMedia(constraints)
        promise.then(function(MediaStream){
            video.srcObject=MediaStream;
            video.play();
        })
     }

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

老师不行喔 报错  是因为我电脑没摄像头吗  但是手机打不开

image.png

WEB前端全系列/第九阶段:HTML5新特性模块/(旧)H5新特性 32楼
WEB前端全系列/第九阶段:HTML5新特性模块/(旧)H5新特性 33楼

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0,user-scalable=no">
    <title>Document</title>
    <script type="text/javascript" src="https://api.map.baidu.com/api?v=1.0&&type=webgl&ak=3VjNpVvk8NXe7psFZkGLo0PbESRilPef"></script>
    <style>
        #container {
            height: 500px;
            width: 700px;
            border: 1px solid black;
        }
    </style>
</head>

<body>
    <button>加载百度地图</button>
    <div id="container">
    </div>
    <script>
        document.querySelector('button').onclick = function() {
            var map = new BMapGL.Map("container");
            // var point = new BMapGL.Point(116.404, 39.915);
            map.addControl(new BMapGL.NavigationControl());

            /*
            一、概念描述
                地址解析服务(地理编码服务):将具体的【地址描述】转换成【经纬度坐标】。
                逆地址解析服务(逆地理编码服务):将【经纬度坐标】转换成具体的【地址描述】
            二、Geocoder  地址解析工具类
                var geoc=new BMap.Geocoder();
                1.geoc.getLocation(point,function(info){...})
                    描述:逆地理解析服务方法
                    本方法的作用是传入一个坐标点,返回坐标点的具体地址描述。
                2.geoc.getPoint(address,function(point){...})
                    描述:地址解析方法
                    本方法的作用是传入一个具体的地址描述,返回这个地址的坐标点。
            */
            // 创建地理编码实例      
            var myGeo = new BMapGL.Geocoder();
            map.addEventListener('click', function(eve) {
                console.log(eve.point);
                myGeo.getLocation(eve.point, function(info) {
                    console.log(info);
                });
            });
            var address = "故宫";
            myGeo.getPoint(address, function(point) {
                console.log(point);
                map.centerAndZoom(point, 15);
            }, '北京市');
        };
    </script>
</body>

</html>

image.png

我在地理编码这一块老是这样出问题,还有自带的一个错误,但是解决不了

WEB前端全系列/第九阶段:HTML5新特性模块/(旧)H5新特性 35楼
WEB前端全系列/第九阶段:HTML5新特性模块/(旧)H5新特性 36楼

老师,这里我这样写是不是对的呀,还请老师帮忙看一下:

<!DOCTYPE html>
<html>

<head lang="en">
    <meta charset='utf-8' />
    <title>lesson4_cookie案例</title>
    <style>
        .loginRegistDiv {
            text-align: center;
            padding: 15px;
            border: 1px solid black;
            width: 300px;
            min-height: 30px;
        }
        
        .welcomeDiv {
            text-align: center;
            padding: 15px;
            border: 1px solid black;
            width: 300px;
            min-height: 30px;
            display: none;
        }
        
        .nickNameSpan {
            color: green;
            font-size: 22px;
            font-weight: bold;
        }
    </style>
</head>

<body>
    <div class="loginRegistDiv">
        <label for="userName">
        <span>用户名:</span><input type="text" id="userName" placeholder='请输入用户名'>
    </label><br/>
        <label for="password">
        <span>密&nbsp;&nbsp;&nbsp;码:</span><input type="text" id="password" placeholder='请输入密码'>
    </label><br/><br/>
        <button class="loginBtn">登录</button>
        <button class="registBtn">注册</button>
    </div>
    <div class="welcomeDiv">
        欢迎回来,尊敬的:
        <span class='nickNameSpan'>哈哈哈</span>
        <br/><br/>
        <button class="exitBtn">注销登录</button>
    </div>
    <script>
        //页面逻辑
        ;
        (function() {
            var loginBtn = document.querySelector('.loginBtn');
            var userNameInput = document.querySelector('#userName');
            var passwordInput = document.querySelector('#password');
            var welcomeDiv = document.querySelector('.welcomeDiv');
            var loginRegistDiv = document.querySelector('.loginRegistDiv');
            var nickNameSpan = document.querySelector('.nickNameSpan');
            var exitBtn = document.querySelector('.exitBtn');

            //表示一个自动登录的功能  
            function getCookie() {
                //获取cookie
                var cookie = document.cookie;
                // 分割成数组
                var cookieArr = cookie.split(';');
                var finalObj = {};
                // 循环遍历,并存入对象
                for (var i = 0; i < cookieArr.length; i++) {
                    var tempArr = cookieArr[i].trim().split('=');
                    finalObj[tempArr[0]] = tempArr[1];
                }
                return finalObj;
            }

            var cookieObj = getCookie();
            if (cookieObj.nickName != undefined) {
                if (cookieObj.nickName.length != 0) {
                    loginRegistDiv.style.display = 'none';
                    welcomeDiv.style.display = 'block';
                    nickNameSpan.innerHTML = cookieObj.nickName;
                }
            }

            // 发送Ajax请求
            loginBtn.onclick = function() {
                var xhr = new XMLHttpRequest();
                xhr.onreadystatechange = function() {
                    if (xhr.readyState == 4) {
                        if (xhr.status == 200) {
                            // 解析
                            var data = JSON.parse(xhr.responseText);
                            // 成功后
                            if (data.loginStatusCode == 1) {
                                loginRegistDiv.style.display = 'none';
                                welcomeDiv.style.display = 'block';
                                nickNameSpan.innerHTML = data.nickName;
                            }
                        }
                    }
                };

                // 采用表单验证方式
                var formData = new FormData();
                formData.append('uname', userNameInput.value);
                formData.append('upass', passwordInput.value);
                xhr.open('post', '07cookie案例后台.php', true);
                xhr.send(formData);
            }

            //退出登录按钮
            exitBtn.onclick = function() {
                // 清空
                userNameInput.value = '';
                passwordInput.value = '';
                // 切换显示隐藏状态
                loginRegistDiv.style.display = 'block';
                welcomeDiv.style.display = 'none';
                //清除cookie
                var expires = new Date(new Date().getTime() + 1).toGMTString();
                document.cookie = 'nickName=beixi;expires=' + expires;
            }
        })();
    </script>
</body>

</html>

<?php
 $success=array('msg'=>'ok');
  $userName=$_POST['uname'];
  $password=$_POST['upass'];

  
   //连接数据库
   $con = mysqli_connect('localhost','root','123456','lanmeipai');

   if($con){
      //修改字符集
      mysqli_query($con,'set names utf8');
      mysqli_query($con,'set character_set_client utf8');
      mysqli_query($con,'set character_set_results utf8');

      //查询数据库并连接
      $sql = 'select * from loginuserinfo where 1';
      $result = $con->query($sql);

      //判断 读取数据库中的用户信息
      // $result->num_rows>0-->有数据
      if($result->num_rows>0){
      $info=[];//创建一个空数组,来存放数据
      for($i=0;$row=$result->fetch_assoc();$i++){
       $info[$i]=$row;
      }

      //判断用户传来的用户名和密码是否在数据库里有着对应的信息
      $flag=false;//标示符,默认登录失败
      for($j=0;$j<count($info);$j++){
         if($info[$j]['userName']==$userName){
            if($info[$j]['password']==$password){
               $success['infoCode']=0;
               $success['nickName']=$username;
               $flag=true;
               break;
            }
         }
      }

      
   //当循环结束后,判断$flag的值
   if(!$flag){
   $success['infoCode']=1;
      }
 
   }else{
   $success['infoCode']=3;
      }
   }else{
   $success['infoCode']=2;//0代表登录成功,1代表登录失败,2代表数据库连接失败,3代表数据库为空
    }


  //登录成功之后对页面添加cookie
  setcookie('nickName','beixi',time()+3600*24);

  //回馈前端表示登录成功,使用状态码loginStatusCode   0表示失败  1表示成功
  $success['loginStatusCode']=1;
  $success['nickName']='beixi';

 echo  json_encode($success);
?>






WEB前端全系列/第九阶段:HTML5新特性模块/(旧)H5新特性 37楼

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Canvas多个小球随机运动.html</title>
    <style>
        canvas{
            border: 1px solid #000;
        }
    </style>
</head>
<body>
<canvas width="400px" height="300px">您的浏览器不支持canvas,请升级浏览器!</canvas>
</body>
<script>
    /*var modul = (function () {
        function getElement(eleName) {
            return document.querySelector(eleName);
        }
        return {
            getElement:getElement
        };
    })();
    var canvas = modul.getElement("canvas");
    var ctx = canvas.getContext("2d");
    console.log(canvas);*/
    var canvas = document.querySelector("canvas");
    var ctx = canvas.getContext("2d");

    function randomColor() {
        var r = parseInt(Math.random() * 256);
        var g = parseInt(Math.random() * 256);
        var b = parseInt(Math.random() * 256);
        var CircleColor = "rgb(" + r + "," + g + "," + b + ")";
        return CircleColor;
    }
    function Circle() {
        this.r = Math.floor(Math.random() * 20 + 11);
        this.x = Math.floor(Math.random() * (400 - this.r));
        this.y = Math.floor(Math.random() * (300 - this.r));
        this.speedX = Math.floor(Math.random() * 8);
        this.speedY = Math.floor(Math.random() * 6);
        this.color = randomColor();
    }
    Circle.prototype.circleSpeed = function () {
        this.x += this.speedX;
        if (this.x <= this.r){
            this.speedX = -this.speedX;
        }else if (this.x >= (400 - this.r)){
            this.speedX = -this.speedX;
        }
        this.y += this.speedY;
        if (this.y <= this.r){
            this.speedY = -this.speedY;
        }else if (this.y >= (300 - this.r)){
            this.speedY = -this.speedY;
        }
    };
    Circle.prototype.drawCircle = function () {
        ctx.beginPath();
        ctx.arc(this.x,this.y,this.r,0,2*Math.PI);
        ctx.fillStyle = this.color;
        ctx.fill();
        ctx.closePath();
    };
    var arr = [];
    for (var i = 0; i < 4; i++){
        arr[i] = new Circle();
    }
    var timer = setInterval(function () {
        ctx.clearRect(0,0,canvas.width,canvas.height);
        for (var i = 0; i < arr.length; i++){
            arr[i] = circleSpeed();
            arr[i] = drawCircle();
        }
    },18);
</script>
</html>

哪里有问题?

WEB前端全系列/第九阶段:HTML5新特性模块/(旧)H5新特性 38楼

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <style>
        canvas{
            width: 250px;
            height: 85px;
            border: 1px solid #000;
            margin: 50px auto;
            display: block;
        }
    </style>
</head>
<body>
<canvas></canvas>
</body>
<script>
    var imgs = ["../image/刮刮乐/p_0.jpg","../image/刮刮乐/p_1.jpg"];
    var flag = 0;
    for (var i = 0; i < imgs.length; i++){
        var img = new Image();
        img.src = imgs[i];
        img.onload = function () {
            flag++;
            if (flag === imgs.length){
                callback();
            }
        }
    }
    function callback() {
        var canvas = document.querySelector("canvas");
        var ctx = canvas.getContext("2d");
        var randomNum = Math.floor(Math.random() * 10);
        if (randomNum === 2){
            canvas.style.background = "url(" + imgs[1] + ")";
        }else{
            canvas.style.background = "url(" + imgs[0] + ")";
        }
        // 想让文字显示在覆盖层的上面
        ctx.fillText("请刮开此区域",10,10);
        //覆盖层
        ctx.fillStyle = "#ccc";
        ctx.fillRect(0,0,canvas.width,canvas.height);
        //刮开效果
        canvas.onmousedown = function () {
            canvas.onmousemove = function (e) {
                var eve = e || window.event;
                var mouseX = eve.offsetX;
                var mouseY = eve.offsetY;
                ctx.clearRect(mouseX,mouseY,15,15);
            };
            canvas.onmouseup = document.onmouseup = function () {
                canvas.onmousemove = null;
            }
        }
    }
</script>
</html>

image.png

1,下边和右边刮不开

2,怎呢让文字显示在覆盖层的上面

WEB前端全系列/第九阶段:HTML5新特性模块/(旧)H5新特性 39楼
WEB前端全系列/第九阶段:HTML5新特性模块/(旧)H5新特性 42楼
WEB前端全系列/第九阶段:HTML5新特性模块/(旧)H5新特性 43楼

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>07cookie案例</title>
    <style>
        .loginDiv{border: 1px solid #666;padding: 30px;width: 300px;}
        .welcomeDiv{border: 1px solid #666;padding: 30px;width: 300px;margin-top: 30px;display: none;}
        .welcome1 span{color: green;font-size: 20px;font-weight: bold;}
    </style>
</head>
<body>
    <div class="loginDiv">
        <div class="login1">
            <label for="">姓名:</label>
            <input type="text" name="" id="userName">
        </div>
        <div class="login1">
            <label for="">密码:</label>
            <input type="text" name="" id="passWord">
        </div>
        <button id="login">登录</button>
        <button id="regist">注册</button>
    </div>
    <div class="welcomeDiv">
        <div class="welcome1">欢迎回来, <span id="nickNameSpan">未登录</span></div>
        <button id="reset">注销登录</button>
    </div>
    <script>
        (function(){
            var login = document.querySelector('#login');
            var regist = document.querySelector('#regist');
            var reset = document.querySelector('#reset');
            var loginDiv = document.querySelector('.loginDiv');
            var welcomeDiv = document.querySelector('.welcomeDiv');
            var userName = document.querySelector('#userName');
            var passWord = document.querySelector('#passWord');
            var nickNameSpan = document.querySelector('#nickNameSpan');
            //表示一个自动登录的功能
            function getCookie(){                
                var cookie = document.cookie;
                var cookieArr = cookie.split(';');
                var finalObj = {};
                for(var i = 0; i < cookieArr.length; i++){
                    var tempArr = cookieArr[i].trim().split('=');
                    finalObj[tempArr[0]] = tempArr[1];
                }
                return  finalObj;
            }
            var cookieObj = getCookie();
            if(cookieObj.nickName != undefined){
                if(cookieObj.nickName.length != 0){
                    welcomeDiv.style.display = 'block';
                    loginDiv.style.display = 'none';
                    nickNameSpan.innerHTML = cookieObj.nickName;
                }
            }

            login.onclick = function(){
                var xhr = new XMLHttpRequest();
                xhr.onreadystatechange = function(){
                    if(xhr.readyState == 4){
                        if(xhr.status == 200){
                            var data = JSON.parse(xhr.responseText);
                            if(data.loginStatusCode == 1){
                                welcomeDiv.style.display = 'block';
                                loginDiv.style.display = 'none';
                                nickNameSpan.innerHTML = data.nickName;
                            }
                        }
                    }
                };
                var formData = new FormData();
                formData.append('uname', userName.value);
                formData.append('pword', passWord.value);
                xhr.open('post', '07cookie案例.php', true);
                xhr.send(formData)
            }
            
            //注销
            reset.onclick = function(){
                userName.value = '';
                passWord.value = '';
                welcomeDiv.style.display = 'none';
                loginDiv.style.display = 'block';
                var expires = new Date(new Date().getTime() + 1).toGMTString();
                document.cookie = "nickName=beixi; expires" + expires;
            }
        })()
    </script>
</body>
</html>

老师,我这个注销的时候cookie清除不了是什么原因

WEB前端全系列/第九阶段:HTML5新特性模块/(旧)H5新特性 44楼

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>cookie复杂存储</title>
</head>
<body>
    <button>点我</button>
    <script>

        (function() {
            var xhr=window.XMLHttpRequest
            ?new XMLHttpRequest()
            :new ActiveXObject();
            xhr.onreadystatechange=function() {
                if(xhr.readyState==4) {
                    if(xhr.status==200) {
                        console.log(xhr.responseText)
                    }
                }
            }
            var datas=new FormData();
            datas.append('name','taige');
            datas.append('hobby','eat');
            xhr.open('post','cookie后台.php',true);
            xhr.send(datas);
        }());
    </script>
</body>
</html>
<?php
    // 处理cookie
    $name=$_POST['name'];
    $hobby=$_POST['hobby'];
    setcookie('name',$name,time()+60*60);
    setcookie('hobby',$hobby,time(+60*60));

    // 给出反馈
    $success=array('msg'=>'ok');
    echo json_encode($success);
?>

老师,我前后台数据都提交了,您看看。我返回的结果是这玩意!!

QQ截图20210210160444.png


WEB前端全系列/第九阶段:HTML5新特性模块/(旧)H5新特性 45楼

课程分类

百战程序员微信公众号

百战程序员微信小程序

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