js对象属性方法的调用问题

丢雷老谋 2015-06-11 05:35:45
比如有如下对象(随便写的,就那么个意思):
var page = {
a : 1,
b : 2,
c : {
d : 3,
e : 4,
f = function(){
//这里!!!怎么调用fun属性方法
},
g : //这里!!!!怎么调用a属性的值1
},
fun : function(){
alert('我是属性方法')
}

}

请忽略语法问题,大概就这么个意思,不知道在此的各位大神有木有办法,指点一下!谢谢!
...全文
962 8 打赏 收藏 转发到动态 举报
写回复
用AI写文章
8 条回复
切换为时间正序
请发表友善的回复…
发表回复
MnZlZ 2015-06-21
  • 打赏
  • 举报
回复
引用 7 楼 gy127132060 的回复:
我也想说,,其实通过定义的page 进行内部引用是个不错的方法。。。
楼主早点结贴给分吧
香蕉猪 2015-06-12
  • 打赏
  • 举报
回复
引用 6 楼 u013104499 的回复:

var page = {
         a : 1,
         b :  2,
         c : {
                d : 3,
                e : 4,
                f : function(){
                  return page.fun();
                },
                g : function(){
                	return page.a;
                }
        },
        fun : function(){
          alert(123);
        }
       }
       page.c.f();
       alert(page.c.g());
我也想说,,其实通过定义的page 进行内部引用是个不错的方法。。。
MnZlZ 2015-06-11
  • 打赏
  • 举报
回复

var page = {
         a : 1,
         b :  2,
         c : {
                d : 3,
                e : 4,
                f : function(){
                  return page.fun();
                },
                g : function(){
                	return page.a;
                }
        },
        fun : function(){
          alert(123);
        }
       }
       page.c.f();
       alert(page.c.g());
遥望那些年 2015-06-11
  • 打赏
  • 举报
回复
一般不都这么做的么?
天际的海浪 2015-06-11
  • 打赏
  • 举报
回复
引用 3 楼 gxttr 的回复:
这种情况你需要一个初始化函数

var page = {
	self:null,
   a : 1,
   b :  2,
   c : {
           d : 3,
           e : 4,
          f : function(){
          self.fun();
         },
         g : null,
   },
   fun : function(){
        alert('我是属性方法');
   },
   create:function(){self=this;self.c.g=self.a;},
}

page.create();
page.c.f();
alert(page.c.g);
经过page.create后,self的值被赋予了当前的this。以后可以通过self来获取当前对象
居然用全局变量self,
遥望那些年 2015-06-11
  • 打赏
  • 举报
回复
这种情况你需要一个初始化函数

var page = {
	self:null,
   a : 1,
   b :  2,
   c : {
           d : 3,
           e : 4,
          f : function(){
          self.fun();
         },
         g : null,
   },
   fun : function(){
        alert('我是属性方法');
   },
   create:function(){self=this;self.c.g=self.a;},
}

page.create();
page.c.f();
alert(page.c.g);
经过page.create后,self的值被赋予了当前的this。以后可以通过self来获取当前对象
天际的海浪 2015-06-11
  • 打赏
  • 举报
回复
这种格式只是一个对象的属性中存放了另一个对象的引用,它们之间不存在实质的父子关系,所以没有办法获取到是哪个对象存放了本对象的引用, 而且, 当多个对象都存放了本对象的引用,更不知道你要获取的是哪个了
丢雷老谋 2015-06-11
  • 打赏
  • 举报
回复
我试过用this 但是在属性g 的地方如果用this会报错为未定义,因为this指向的竟然是document,偶买噶!f属性方法中用this更不可能实现
第1 章 JavaScript 基 础 1.1 关 于JavaScript 1.2 了 解JavaScript 1.3 World Wide Web 1.4 Web 应用程序结构 1.5 JavaScript 与VBScript 第2 章 JavaScript 与HTML 2.6 HTML 基 础 2.7 在HTML 文档中嵌入JavaScript 2.8 编写JavaScript 脚本 第3 章 JavaScript 基本语法 3.9 JavaScript 基本数据结构 3.10 JavaScript 运算符和表达式 3.11 JavaScript 控制结构和循环 第4 章 Window 窗口对象 4.12 Window 窗口对象属性 4.13 Window 窗口对象方法 4.14 创建和关闭窗口 第5 章 document 对 象 5.15 document 对象属性 5.16 document 对象方法 第6 章 文 本 对 象 6.17 文本对象属性 6.18 文本对象方法 6.19 文本对象的事件 6.20 文本区域对象 第7 章 按 钮 对 象 7.21 button submit reset 对 象 7.22 复选框对象 7.23 Radio 对 象 第8 章 选择和隐藏对象 8.24 select 对 象 8.25 隐 含 对 象 第9 章 location 对 象 9.26 hash 属 性 9.27 Href 属 性 9.28 pathname 属 性 9.29 Protocol 属 性 第10 章 history 对 象 第11 章 layer 对 象 11.30 layer 属 性 11.31 layer 对象方法 11.32 JavaScript 操作层 第12 章 字符串对象 12.33 转 义 字 符 12.34 字符串对象属性 12.35 字符串对象方法 第13 章 日期对象 13.36 时间对象属性 13.37 时间对象的设置 第14 章 数 学 对 象 14.38 math 对象属性 14.39 math 对象方法 第15 章 数 组 对 象 15.40 数组对象的创建 15.41 数组对象的扩充 15.42 对象类数组 第16 章 样式单实例 16.43 样式单的实用 16.44 样式单的定义 16.45 样式单的使用 第17 章 实用小程序 17.46 导 言 17.47 状态栏滚动信息 17.48 计算用户来访次数 17.49 散布页面的星星 17.50 永在顶端的图片 第18 章 JavaScript 语言的扩展 18.51 ActiveX 通 信 18.52 调用插入件 第19 章 网上购物系统 19.53 示 例 特 性 19.54 源 代 码 19.55 功 能 概 述 19.56 程 序 详 解 第20 章 2000 珍藏版 20.57 Cookie 入 门 20.58 实 例 特 性 20.59 程序源代码 20.60 功 能 概 述 20.61 程 序 详 解 第21 章 时 钟 日 历 21.62 示 例 特 性 21.63 源 代 码 21.64 功 能 概 述 21.65 程 序 详 解 第22 章 JavaScript 服务器端编程 22.66 预 备 知 识 22.67 实 例 学 习 22.68 功 能 概 述 22.69 脚 本 详 解 第23 章 网络安全性 23.70 安全性破坏的种类 23.71 安 全 服 务

87,907

社区成员

发帖
与我相关
我的任务
社区描述
Web 开发 JavaScript
社区管理员
  • JavaScript
  • 无·法
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧