페이지가 로드된 후 연결 문제가 자주 발생합니다. 이때, 후속 링크가 웹 페이지에 표시될 수 있도록 페이지가 로드된 후 첫 번째 클릭 이벤트가 자동으로 트리거되도록 해야 합니다.
js
$("selector").trigger("click");
trigger 메소드를 사용할 수 있습니다. 예를 들어 제 코드에서는 먼저 ul의 li에 클릭 이벤트를 추가한 다음 이 이벤트 트리거를 시뮬레이션했습니다.
$(".place-classify ul").on("click","li",function(){ var placeName = $(this).html(); createPlaceContent(placeName) ; }); $(".place-classify ul li:first-child").trigger('click');
그러나 시뮬레이션된 이벤트가 실행되지 않는 경우가 있습니다. 일반적으로 두 가지 문제가 발생할 수 있습니다.
시뮬레이트된 클릭 이벤트가 클릭 이벤트 앞에 작성됩니다.
어떤 사람들은 이것이 페이지가 로드된 후에 트리거된다고 생각합니다. 특히 $(function(){});
로 작성된 경우 먼저 렌더링된 다음 트리거되지만 페이지가 열리면 전체 페이지가 먼저 렌더링됩니다. js 코드가 아닌 페이지의 요소가 하나씩 실행됩니다. 시뮬레이션된 클릭이 앞에 작성되면 먼저 트리거된 후 선언되므로 아무 것도 발생하지 않습니다. 효과를 클릭 이벤트 뒤로 이동하면 됩니다. $(function(){});
当中就是先渲染在触发,但是一个页面打开先渲染的是整个页面的元素,而不是js代码,js代码还是会一条条的往下执行,那么把模拟点击写在前面的话就是先触发再声明,所以没有效果,把他移到点击事件的后面就可以了。
已经把点击事件移到了后面但还是没有触发,那么可能是异步加载的原因,由于你的网页是异步加载那么由于数据还没有处理完你就发生了点击事件,同样的道理,动态生成的元素都还没有生成,就触发了点击事件。办法就是把ajax请求改为同步请求。$.ajax({ <br>
url:url, <br>
data:data, <br>
async:false, <br>
success:function(result){ <br>
handle(result); <br>
}, <br>
error:function(result){ <br>
alert("获取数据失败"); <br>
} <br>
});
위 내용은 js는 클릭 이벤트를 시뮬레이션합니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!