V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
V2EX 提问指南
hansnow
V2EX  ›  问与答

关于 Ajax 的一些疑惑

  •  
  •   hansnow · 2014-11-09 10:18:47 +08:00 · 2322 次点击
    这是一个创建于 3667 天前的主题,其中的信息可能已经有所发展或是发生改变。
    想做下面这样一个页面:
    
    由两部分组成:Nav,Main. 其中Main包含两部分:Side,Content.

    现在想实现这样一种效果:点击Nav中的各个标签(按钮)的时候,Main中的内容会相应改变。单独看Main的话,Side中的各个标签(按钮)被点击时,Content中的内容会随之改变。

    点击Nav改变Main这个我会做,用jQuery的load就可以。那么请问能否通过Ajax实现点击Side改变Content呢?因为我测试的时候发现通过Ajax加载出的页面中包含的javascript代码是不会执行的。

    请问如何实现上面我要实现的效果?
    13 条回复
    justfindu
        1
    justfindu  
       2014-11-09 10:35:37 +08:00
    load之后绑定side dom 事件
    hansnow
        2
    hansnow  
    OP
       2014-11-09 10:42:50 +08:00
    @justfindu 绑定事件用jQuery中的bind()可以吗?我把他放在load()之后没有效果诶
    justfindu
        3
    justfindu  
       2014-11-09 10:44:53 +08:00
    @hansnow 成功之后
    Jaylee
        4
    Jaylee  
       2014-11-09 10:52:19 +08:00   ❤️ 1
    请用iframe
    hansnow
        5
    hansnow  
    OP
       2014-11-09 10:54:10 +08:00
    @justfindu 额。。。还是不太懂额。。。现在点击Nav切换Main的load()代码是写在html<head>中的$(document).ready()里,请问您说的绑定side dom事件是写在哪里?应该怎么写?
    hansnow
        6
    hansnow  
    OP
       2014-11-09 10:55:16 +08:00
    @Jaylee <iframe style="display:none" onload="javascript: function_onload()"></iframe>

    请问是这种吗?
    airyland
        7
    airyland  
       2014-11-09 10:58:14 +08:00   ❤️ 1
    jQuery ajax加载html时里面的script代码是会执行的。
    justfindu
        8
    justfindu  
       2014-11-09 11:04:31 +08:00   ❤️ 1
    @hansnow load 的 callback , 或者如楼上的 直接在加载的html代码里面写
    hansnow
        9
    hansnow  
    OP
       2014-11-09 11:05:07 +08:00
    @airyland 哦!真的是这样。开始时我load了某个html中的某一个div中的内容。现在load整个HTML就可以了执行了!但是我不想把每个小页面的代码分别放入一个单独文件中。这样的话要怎么做呢?
    emric
        10
    emric  
       2014-11-09 11:13:54 +08:00
    事件委托
    hansnow
        11
    hansnow  
    OP
       2014-11-09 11:15:12 +08:00
    @justfindu
    @Jaylee
    @airyland

    谢谢各位,问题已经解决了,而且还不止一种解决方式。

    1、在load()函数的callback函数里直接写要加载出来的js代码
    2、load()函数加载整个HTML文件时是可以执行里面的js代码的(但不知道什么原因,只加载一部分的话就不能执行)
    3、在要加载的页面中加入iframe代码:<iframe style="display:none" onload='javascript:your_js_code_here'>
    hansnow
        12
    hansnow  
    OP
       2014-11-09 11:15:36 +08:00
    @emric 又是一个新名词……我去学习下……
    dong3580
        13
    dong3580  
       2014-11-09 11:18:38 +08:00
    点击Ajax实现点击Side改变Content完全可以写个common.js,母页面引用呗,
    子页面会自动集成母页面所有的js的,
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   1243 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 21ms · UTC 18:10 · PVG 02:10 · LAX 10:10 · JFK 13:10
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.