javascript - 在 AJAX 响应后,翻转插件和 javascript 功能不起作用
问题描述
我正在使用Flip插件为 MySQL 表的每一行创建一个 div 并通过 AJAX 带来结果,在 div 前面我显示名称并在 div 后面显示一些信息。这是我的代码:
索引.html
<div class="result"></div>
<script src="https://code.jquery.com/jquery-1.12.0.min.js"></script>
<script src="https://cdn.rawgit.com/nnattawat/flip/master/dist/jquery.flip.min.js"></script>
<script>
$.post("result.php",{
}).done(function(resp){
$(".result").html(resp);
});
$(".fff").flip({
trigger: 'manual'
});
function flip_back(idx){
$(".card_"+idx).flip(true);
}
function flip_front(idx){
$(".card_"+idx).flip(false);
}
</script>
结果.php
<?php
$connect = mysqli_connect("localhost", "root", "mypass", "mydatabase");
$sql = "SELECT * FROM users";
$res = mysqli_query($connect,$sql);
$html='';
if(mysqli_num_rows($res)>0){
while($row=mysqli_fetch_array($res,MYSQLI_ASSOC)){
$id= $row['id'];
$html.='<div class="card_'.$id.' fff">
<div class="front">'.$row['name'].'
<button onclick="flip_back(\''.$id.'\');">MORE INFO</button>
</div>
<div class="back">'.$row['email'].'Back content
<button onclick="flip_front(\''.$id.'\');">RETURN</button>
</div></div>';
}
echo $html;
}
?>
问题是Flip插件和onclick javascript 功能不起作用,我也尝试使用这种方法:
$.post("result.php",{
}).done(function(resp){
$(".result").html(resp);
});
$(document).on("load",function(){
$(".fff").flip({
trigger: 'manual'
});
function flip_back(idx){
$(".card_"+idx).flip(true);
}
function flip_front(idx){
$(".card_"+idx).flip(false);
}
});
或这个:
$(document).on("load",function(){
$.post("test2.php",{
}).done(function(resp){
$(".result").html(resp);
});
});
$(".fff").flip({
trigger: 'manual'
});
function flip_back(idx){
$(".card_"+idx).flip(true);
}
function flip_front(idx){
$(".card_"+idx).flip(false);
}
我也检查了这个问题,我试过这个:
$(".fff").flip({
trigger: 'manual',
onBefore: function(){
console.log('before starting the animation');
$.post("result.php",{
}).done(function(resp){
$(".result").html(resp);
});
}
});
function flip_back(idx){
$(".card_"+idx).flip(true);
}
function flip_front(idx){
$(".card_"+idx).flip(false);
}
但它仍然无法正常工作。我该如何解决?
我需要你的帮助。
解决方案
最后,它将翻转功能放入 AJAX 响应中:
$.post("result.php",{
}).done(function(resp){
$(".result").html(resp);
$(".fff").flip({
trigger: 'manual'
});
});
function flip_back(idx){
$(".card_"+idx).flip(true);
}
function flip_front(idx){
$(".card_"+idx).flip(false);
}
如果您有其他选择,那就太好了。
推荐阅读
- qbfc - QBFC - 错误模块名称:ucrtbase.DLL 异常代码:0xc0000409
- c - 如果变量在声明时初始化并链接到 NOLOAD 部分,有没有办法引发链接时间错误?
- javascript - 无法为 Read More/Read Less Toggle 更改子类的 innerHTML
- group-by - 如果相同的案例 ID 发生在正在查看的案例之前,如何将案例标记为“重新打开”
- mysql - 需要 Laravel 查询转换
- php - 为什么我不能从 PHP 调用我的 MySQL 程序?
- java - 有没有办法让 Apache Commons FileAlterationMonitor 只对一批传入文件发出一次警报?
- python - 如何修复“myClass 没有对象成员”
- powershell - Publish-PSArtifactUtility 在发布时无法解决模块依赖关系,即使它们在同一个提要中也是如此
- javascript - 第二个 yAxes 值无法使用 Chart.js 正确绘制图表