会员可以在此提问,百战程序员老师有问必答
对大家有帮助的问答会被标记为“推荐”
看完课程过来浏览一下别人提的问题,会帮你学得更全面
截止目前,同学们一共提了 132358个问题
WEB前端全系列/第二阶段:JavaScript编程模块/浏览器模型(BOM) 452楼

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>封装和公私有</title>
</head>
<body>
<script>
    /*
    封装
    描述:封装是指构造具有某种特征的类,以通过对其进行实例化,来获得满足
        需求的对象的过程
    特征:
      公有:对象中属性和方法,在对象外部能够直接访问,这样的属性和方法就
            称为公有的属性和方法
      私有:对象中属性和方法,仅在对象内部使用,这样的属性和方法就
            称为私有的属性和方法
      实现:
        通过在构造函数中,(this.属性)的方法为类添加公有的属性和方法
            this.属性添加的内容在对象的外部能够直接被访问
        通过在构造函数中,(添加局部变量和闭包)的方式为类添加私有的属性和方法
            局部变量保证了对象外部无法直接获取
            闭包保证了对象外部可以间接获取
      特权函数:
        在js对象中能够用来访问内部局部变量的函数
        使用特权来模拟私有的赋值调用过程
        例子:
    function People(pname,pability) {
        //公有的属性和方法
        this.pname=pname;
        this.ability=pability;
        //js局部变量来模拟私有属性和方法
        var secret='梦';
    }
    var beixi=new People('贾先生',function () {
        console.log('敲代码');
    });
    console.log(beixi.pname);
    beixi.pability();
    //私有的属性和方法不能在对象之外直接访问
    //console.log(beixi.secret);
    beixi.getSecret();

     */
    function People(pname,pability,eyesNum) {
        //公有的属性和方法
        this.pname=pname;
        this.ability=pability;
        //js局部变量来模拟私有属性和方法
        var secret='梦';
        //特权函数
        this.getSecret=function () {
            console.log(secret);
        }

        this.eyesNum=eyesNum;
    }
    //prototype原型:为了解决js模拟面向对象时,一些(共同拥有的属性值)
        //而出现的解决方法
    People.prototype.eyesNum=2;
    People.prototype.breahte=function(){
        console.log('呼吸');
    }
    var beixi=new People('贾先生',function () {
        console.log('敲代码');
    });
    var liushishi=new People('刘诗诗',function () {
        console.log('卖萌');
    });
    //公有的属性和方法能够在对象之外直接访问
    console.log(beixi.pname);
    beixi.pability();
    //私有的属性和方法不能在对象之外直接访问
    //console.log(beixi.secret);
    beixi.getSecret();
    console.log(beixi.eyesNum);
    console.log(liushishi.eyesNum);
    beixi.breahte();
    liushishi.breahte();
</script>
</body>
</html>

老师,我这个

beixi.pability();
    //私有的属性和方法不能在对象之外直接访问

这一个地方在浏览器报错了,后面出不来了


WEB前端全系列/第二阶段:JavaScript编程模块/正则对象 457楼

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>自定义右键菜单</title>
    <style>
        *{margin: 0;padding: 0;}
        ul{
            list-style: none;
            background-color: darkgray;
            min-width: 220px;
            display: inline-block;
            position: absolute;
            display: none;
        }
        ul li{
            height: 30px;
            line-height: 30px;
            padding: 5px 20px;
            cursor: pointer;/*光标变小手*/
            transition:0.3s;
        }
        ul li:hover{
            background-color: orange;
            color: white;
        }
    </style>
</head>
<body>
<ul>
    <li>我想你了!</li>
    <li>你真的忍心离开本页面吗?</li>
    <li>去百度搜索页面中选中的内容</li>
    <li>输入内容然后去百度搜索</li>
</ul>
<textarea  cols="80" rows="20"></textarea>
<script>
    var ul=document.querySelector('ul');
    //系统右键菜单禁用事件【contextmenu】
    document.oncontextmenu = function (eve) {
        return false; //return false表示事件禁用
    }
    document.onmouseup=function (eve) {
        //eve.button能够判断鼠标用的是哪个按钮
        //0 左键   1滚轮    2右键
        if (eve.button==2){
            ul.style.display='inline-block';
            //设置鼠标点击的位置
            ul.style.left=eve.clientX+'px';
            ul.style.top=eve.clientY+'px';
        }else {
            //关闭菜单
            ul.style.display='none';
        }
    }
    //点击某一个菜单选项时触发的事件(事件委托)
    ul.onmousedown=function (eve) {
        if (eve.target.innerHTML=='我想你了!'){
            alert('那就去吧,她在北京三区');
        }else if (eve.target.innerHTML=='你真的忍心离开本页面吗!'){
            if (confirm('你真的忍心离开本页面吗!')){
                window.close();
            }
        }else if (eve.target.innerHTML=='去百度搜索页面中选中的内容!'){
            var resukt=document.getSelection().toString();
            window.open('http://www.baidu.com/s?wd='+resukt);
        }else{
            var result=prompt('输入内容然后去百度搜索');
            window.open('http://www.baidu.com/s?wd='+result);
        }
    }
</script>
</body>
</html>

老师,我这个第三个功能实现不了,我也不知道是什么原因?

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

1练习中问题一

老师金字塔是怎么做出的呢,我的代码是在哪一处有了问题的呢


代码

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>for循环联系打印</title>
</head>
<body>
<script>
   /* /!*打印5行5列的矩形
    * * * * *
    * * * * *
    * * * * *
    * * * * *
    * * * * *
    *!/
    for (var j=1;j<5;j++){  //外层循环控制行
        for (var i=1;i<5;i++){  //内层循环控制列
            document.write("*")
        }
        document.write("<br/>");
    }*/

    /*打印5行5列的矩形
    *
    * *
    * * *
    * * * *
    * * * * *

   for (var j=1;j<5;j++){  //外层循环控制行
       for (var i=1;i<=j;i++){  //内层循环控制列
           document.write("*")
       }
       document.write("<br/>");
   }*/
   /*打印5行5列的矩形
        *
       * *
      * * *
     * * * *
    * * * * *
    */
   var alt="";
    for (var i=1;i<=5;i++){  //控制行
        var blank=""
        for (var j=1;j<=5-i;j++){  //空白三角形
            blank+=""
        }
        var stars="";
        for (var m=1;m<=2*i-1;m++){
            stars+="*";
        }
        alt+=blank+stars+"\n";
    }
    console.log(alt);

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

运行图.

image.png


作业图image.png


WEB前端全系列/第二阶段:JavaScript编程模块/运算符_数据类型和流程循环语句 462楼

课程分类

百战程序员微信公众号

百战程序员微信小程序

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