- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我的主题是使用 Jplayer 作为音乐播放器。但有一个问题,有时音乐无缘无故地开始播放,而我没有点击播放按钮。有时我暂停播放器并刷新页面或移动到另一个页面,然后播放器从头开始。如何解决此问题并禁用播放器的自动播放?
jQuery(document).ready(function(a) {
"use strict";
function s(a) {
for (var s = a + "=", t = document.cookie.split(";"), e = 0; e < t.length; e++) {
for (var i = t[e];
" " == i.charAt(0);) i = i.substring(1);
if (0 == i.indexOf(s)) return i.substring(s.length, i.length)
}
return ""
}
function t(a, s, t) {
var e = new Date;
e.setTime(e.getTime() + 24 * t * 60 * 60 * 1e3);
var i = "expires=" + e.toUTCString();
document.cookie = a + "=" + s + ";" + i + ";path=/"
}
jQuery(function(e) {
if (e(".audio-player").length) {
var i = "",
r = new jPlayerPlaylist({
jPlayer: "#jquery_jplayer_1",
cssSelectorAncestor: "#jp_container_1"
}, [], {
swfPath: "js/plugins",
supplied: "oga, mp3",
wmode: "window",
useStateClassSkin: !0,
autoBlur: !1,
smoothPlayBar: !0,
keyEnabled: !0,
playlistOptions: {
autoPlay: false,
enableRemoveControls: !0
},
});
e(".play_hover").on("click", function() {
var a = e(this).closest("ul").children("li:eq(1)").find("a").attr("data-musicid"),
s = e(this).closest("ul"),
t = "musicid=" + a;
t += "&action=miraculous_play_single_music_action", e(".ms_ajax_loader").show(), e.ajax({
type: "post",
url: frontadminajax.ajax_url,
data: t,
success: function(a) {
var t = JSON.parse(a);
"false" != t.status ? (r.add({
image: t.image,
title: t.song_name,
artist: t.artists,
mp3: t.mp3url,
id: t.mid,
share: t.share_uri,
option: i
}), e(".ms_ajax_loader").hide(), r.play(-1), e(".ms_list_songs").removeClass("play_active_song"), e(".ms_player_wrapper").removeClass("close_player"), e(s).addClass("play_active_song"), localStorage.setItem("jp_playlist", JSON.stringify(r))) : (e(".ms_ajax_loader").hide(), toastr.error(t.msg))
}
})
}), e(".play_single_music").on("click", function() {
var a = e(this).closest("ul").children("li:eq(1)").find("a").attr("data-musicid"),
s = e(this).closest("ul"),
t = "musicid=" + a;
t += "&action=miraculous_play_single_music_action", e(".ms_ajax_loader").show(), e.ajax({
type: "post",
url: frontadminajax.ajax_url,
data: t,
success: function(a) {
var t = JSON.parse(a);
"false" != t.status ? (r.add({
image: t.image,
title: t.song_name,
artist: t.artists,
mp3: t.mp3url,
id: t.mid,
share: t.share_uri,
option: i
}), e(".ms_ajax_loader").hide(), r.play(-1), e(".ms_list_songs").removeClass("play_active_song"), e(".ms_player_wrapper").removeClass("close_player"), e(s).addClass("play_active_song"), localStorage.setItem("jp_playlist", JSON.stringify(r))) : (e(".ms_ajax_loader").hide(), toastr.error(t.msg))
}
})
}), e(".play_list_music").on("click", function() {
var a = "playlist=" + e(this).attr("data-list");
a += "&action=miraculous_play_user_playlist", e(".ms_ajax_loader").show(), e.ajax({
type: "post",
url: frontadminajax.ajax_url,
data: a,
success: function(a) {
var s = JSON.parse(a);
"false" != s.status ? (e.each(s, function(a, s) {
r.add({
image: s.image,
title: s.song_name,
artist: s.artists,
mp3: s.mp3url,
id: s.mid,
share: s.share_uri,
option: i
})
}), e(".ms_ajax_loader").hide(), r.play(0), e(".ms_player_wrapper").removeClass("close_player"), localStorage.setItem("jp_playlist", JSON.stringify(r))) : (e(".ms_ajax_loader").hide(), toastr.error(s.msg))
}
})
}), e(document).on("click", ".play_music", function() {
e(this).removeClass("play_music"),
e(this).addClass("pause_music btn_pause");
var a = e(this).attr("data-musicid"),
s = e(this).attr("data-musictype"),
t = "musicid=" + a + "&musictype=" + s;
t += "&action=miraculous_play_all_music_action",
e(".ms_ajax_loader").show(),
r.remove(0),
e.ajax({
type: "post",
url: frontadminajax.ajax_url,
data: t,
success: function(a) {
var t = JSON.parse(a);
"false" != t.status ? (e.each(t, function(a, s) {
r.add({
image: s.image,
title: s.song_name,
artist: s.artists,
mp3: s.mp3url,
id: s.mid,
share: s.share_uri,
option: i
})
}), e(".ms_ajax_loader").hide(), "radio" == s && e(".audio-player").addClass("ms_played_radio"),
r.play(0),
e(".ms_list_songs").removeClass("play_active_song"),
e(".ms_player_wrapper").removeClass("close_player"),
localStorage.setItem("jp_playlist", JSON.stringify(r))) : toastr.error(t.msg)
}
})
}), e(document).on("click", ".pause_music", function() {
e(this).removeClass("pause_music btn_pause"), e(this).addClass("play_music"), e("#jquery_jplayer_1").jPlayer("pause")
}),
e(".add_to_queue").on("click", function() {
var a = "musicid=" + e(this).attr("data-musicid") + "&musictype=" + e(this).attr("data-musictype");
a += "&action=miraculous_add_to_queue_action", e(".ms_ajax_loader").show(), e.ajax({
type: "post",
url: frontadminajax.ajax_url,
data: a,
success: function(a) {
var s = JSON.parse(a);
"false" != s.status ? (e.each(s, function(a, s) {
0 == a && e(".jp-now-playing").html().length <= 0 && (e(".jp-now-playing").html("<div class='jp-track-name'><span class='que_img'><img src='" + s.image + "'></span><div class='que_data'>" + s.song_name + " <div class='jp-artist-name'>" + s.artists + "</div></div></div>"), e(".jp_cur_download").attr("data-msmusic", s.mid), e(".jp_cur_favourite").attr("data-musicid", s.mid), e(".jp_cur_playlist").attr("data-msmusic", s.mid), e(".jp_cur_share").attr("data-shareuri", s.share_uri), e(".jp_cur_share").attr("data-sharename", s.song_name)), r.add({
image: s.image,
title: s.song_name,
artist: s.artists,
mp3: s.mp3url,
id: s.mid,
share: s.share_uri,
option: i
})
}), e(".ms_ajax_loader").hide(), e(".ms_player_wrapper").removeClass("close_player"), toastr.success("Added.")) : toastr.error(s.msg)
}
})
}), e(".save_queue_list").on("click", function() {
var a = JSON.stringify(r),
s = "musiclist=" + a;
s += "&action=miraculous_user_queue_data_action", e(".ms_ajax_loader").show(), a ? e.ajax({
type: "post",
url: frontadminajax.ajax_url,
data: s,
success: function(a) {
var s = JSON.parse(a);
"success" == s.status ? toastr.success(s.msg) : toastr.error(s.msg), e(".ms_ajax_loader").hide()
}
}) : toastr.error("Empty.")
}), e(".ms_remove_all").on("click", function() {
r.remove(), localStorage.removeItem("jp_playlist"), e("#jquery_jplayer_1").jPlayer("clearMedia"), toastr.success("Removed all from Queue"), e("#clear_modal").modal("hide"), e(".ms_list_songs").removeClass("play_active_song"), e(".ms_empty_queue").html("Queue is empty"), e(".jp-now-playing").html(""), e(".ms_player_wrapper").addClass("close_player")
}), e(".ms_cancel").on("click", function() {
e("#clear_modal").modal("hide")
}), e(window).on("load", function() {
var a = JSON.parse(localStorage.getItem("jp_playlist"));
localStorage.getItem("current_song", l);
if (a) {
var t = a.playlist,
l = a.current;
e.each(t, function(a, s) {
r.add({
image: s.image,
title: s.title,
artist: s.artist,
mp3: s.mp3,
id: s.id,
share: s.share,
option: i
}), a == l && (e(".jp-now-playing").html("<div class='jp-track-name'><span class='que_img'><img src='" + s.image + "'></span><div class='que_data'>" + s.title + " <div class='jp-artist-name'>" + s.artist + "</div></div></div>"), e(".jp_cur_download").attr("data-msmusic", s.id), e(".jp_cur_favourite").attr("data-musicid", s.id), e(".jp_cur_playlist").attr("data-msmusic", s.id), e(".jp_cur_share").attr("data-shareuri", s.share), e(".jp_cur_share").attr("data-sharename", s.title)), localStorage.setItem("current_song", l)
});
var o = s("MJTCURRENTTIME"),
n = s("MJTCURRENTSONG");
"" != o && "" != n && r.play(n, parseInt(o))
} else {
var u = "musiclist=queue";
u += "&action=miraculous_user_load_queue_data_action", e.ajax({
type: "post",
url: frontadminajax.ajax_url,
data: u,
success: function(a) {
var s = JSON.parse(a);
if ("success" == s.status) {
var t = JSON.parse(s.queue_data);
if (t) {
var l = t.playlist,
o = t.current;
e.each(l, function(a, s) {
r.add({
image: s.image,
title: s.title,
artist: s.artist,
mp3: s.mp3,
id: s.id,
share: s.share,
option: i
}), a == o && (e(".jp-now-playing").html("<div class='jp-track-name'><span class='que_img'><img src='" + s.image + "'></span><div class='que_data'>" + s.title + " <div class='jp-artist-name'>" + s.artist + "</div></div></div>"), e(".jp_cur_download").attr("data-msmusic", s.id), e(".jp_cur_favourite").attr("data-musicid", s.id), e(".jp_cur_playlist").attr("data-msmusic", s.id), e(".jp_cur_share").attr("data-shareuri", s.share), e(".jp_cur_share").attr("data-sharename", s.title)), localStorage.setItem("current_song", o)
})
}
}
"default" == s.status && (r.add({
image: s.image,
title: s.song_name,
artist: s.artists,
mp3: s.mp3url,
id: s.mid,
share: s.share_uri,
option: i
}), e(".jp-now-playing").html("<div class='jp-track-name'><span class='que_img'><img src='" + s.image + "'></span><div class='que_data'>" + s.song_name + " <div class='jp-artist-name'>" + s.artists + "</div></div></div>"), e(".jp_cur_download").attr("data-msmusic", s.mid), e(".jp_cur_favourite").attr("data-musicid", s.mid), e(".jp_cur_playlist").attr("data-msmusic", s.mid), e(".jp_cur_share").attr("data-shareuri", s.share_uri), e(".jp_cur_share").attr("data-sharename", s.song_name))
}
})
}
}), e("#jquery_jplayer_1").on(e.jPlayer.event.ready + " " + e.jPlayer.event.play, function(a) {
var s = r.current,
t = r.playlist;
e.each(t, function(a, t) {
a == s && (e(".jp-now-playing").html("<div class='jp-track-name'><span class='que_img'><img src='" + t.image + "'></span><div class='que_data'>" + t.title + " <div class='jp-artist-name'>" + t.artist + "</div></div></div>"), e(".jp_cur_download").attr("data-msmusic", t.id), e(".jp_cur_favourite").attr("data-musicid", t.id), e(".jp_cur_playlist").attr("data-msmusic", t.id), e(".jp_cur_share").attr("data-shareuri", t.share), e(".jp_cur_share").attr("data-sharename", t.title)), localStorage.setItem("current_song", s), i = "musicid=" + t.id, i += "&action=miraculous_play_single_music_action", e.ajax({
type: "post",
url: frontadminajax.ajax_url,
data: i,
success: function(a) {}
})
}), e(".knob-wrapper").mousedown(function() {
return e(window).mousemove(function(a) {
var s = function(a) {
var s = a.css("-webkit-transform") || a.css("-moz-transform") || a.css("-ms-transform") || a.css("-o-transform") || a.css("transform");
if ("none" !== s) var t = s.split("(")[1].split(")")[0].split(","),
e = t[0],
i = t[1],
r = Math.round(Math.atan2(i, e) * (180 / Math.PI));
else r = 0;
return r < 0 ? r + 360 : r
}(e(".knob")) / 270;
s > 1 ? e("#jquery_jplayer_1").jPlayer("volume", 1) : s <= 0 ? e("#jquery_jplayer_1").jPlayer("mute") : (e("#jquery_jplayer_1").jPlayer("volume", s), e("#jquery_jplayer_1").jPlayer("unmute"))
}), !1
}).mouseup(function() {
e(window).unbind("mousemove")
});
var i = !1;
e(".jp-play-bar").mousedown(function(a) {
i = !0, l(a.pageX)
}), e(document).mouseup(function(a) {
i && (i = !1, l(a.pageX))
}), e(document).mousemove(function(a) {
i && l(a.pageX)
});
var l = function(a) {
var s = e(".jp-progress"),
t = 100 * (a - s.offset().left) / s.width();
t > 100 && (t = 100), t < 0 && (t = 0), e("#jquery_jplayer_1").jPlayer("playHead", t), e(".jp-play-bar").css("width", t + "%")
};
e("#playlist-toggle, #playlist-text, #playlist-wrap li a").unbind().on("click", function() {
e("#playlist-wrap").fadeToggle(), e("#playlist-toggle, #playlist-text").toggleClass("playlist-is-visible")
}), e(".hide_player").unbind().on("click", function() {
e(".audio-player").toggleClass("is_hidden"), e(this).html('<i class="fa fa-angle-down"></i> HIDE' == e(this).html() ? '<i class="fa fa-angle-up"></i> SHOW PLAYER' : '<i class="fa fa-angle-down"></i> HIDE')
}), e("body").unbind().on("click", ".audio-play-btn", function() {
e(".audio-play-btn").removeClass("is_playing"), e(this).addClass("is_playing");
var a = e(this).data("playlist-id");
r.play(a)
})
}), a("#jquery_jplayer_1").bind(a.jPlayer.event.play, function(s) {
t("MJTCURRENTSONG", r.current, 1), a("#jquery_jplayer_1").bind(a.jPlayer.event.timeupdate, function(a) {
t("MJTCURRENTTIME", Math.trunc(a.jPlayer.status.currentTime), 1)
})
})
}
})
});
最佳答案
在 JPlayer 上 demo page在“控制标志描述”部分
autoPlay : Boolean : Will auto-play when instanced on the page, and when a new playlist is given using
它在您的代码中具有真实值(value)。可能这是一个问题。
更新:
我还看到 window “load” 事件处理程序中的 play() 操作。如果 LocalStorage 有有关播放列表的信息,则会调用它。所以它看起来像你的场景
关于javascript - 在 JPlayer 中禁用自动启动,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59581463/
在gdb中获取此消息。我知道它不是错误或任何东西。我也做了分页,所以那不是问题。 有什么办法可以抑制此消息? 最佳答案 我很好奇看到这个问题没有得到解决... 我获得了GDB manual,它说(部分
好吧,这很烦人,而且可能很简单。我想用禁用的复选框启动我的网页,并在选择列表框中的特定行后启用这些框。所以我把它放在 onload 方法中 onload = function () { for
看来我需要以某种方式在我的 php 页面上禁用 IPv6,但我不确定该怎么做。我想我必须在我的 INI 文件中的某处添加 --disable-ipv6 ……虽然这看起来不像正确的语法。 我正在尝试解决
我有这两个代码: 第一个是禁用复制粘贴的宏: Sub Desable_Copy() Dim oCtrl As Office.CommandBarControl For Each oCt
在下面的代码中,我想, 如果我选择/单击“患者类型”按钮。它们在菜单“xmenumain”“儿科心电图”项中应该被禁用(它应该列在菜单列表中,但颜色为淡灰色)。我如何实现它? void MyMenu:
我目前在 Coordinator 布局中有一个底部导航栏,我向其添加了 HideBottomViewOnScrollBehaviour。有些屏幕需要隐藏导航栏,我可以通过从 BottomNavigat
我需要一些关于 jquery if 条件的帮助。我已经搜索和测试了几个小时,任何帮助都会很棒!我得到这个 HTML 代码: Value: No Match Test Test 2 Test 3
我正在开发 Delphi -7 中的自定义组件我有一些published特性 private { Private declarations } FFolderzip ,Fi
尝试学习菜单处理的基础知识。我的测试应用程序的菜单栏有 3 个菜单——即“TestApp”、“File”和“Help”。我发现我可以完全删除这些菜单,只需调用 say: NSMenu* rootMen
我以编程方式创建一个 NSMenuItem,但它被禁用。如果我重写 validateMenuItem: 方法并为所有项目返回 YES,则菜单项工作正常。 当我告诉菜单 autoEnableItems
我的 Web 表单中有一个 asp 按钮 (runat="server") 进入更新面板。 当我点击这个按钮时,它会执行一些操作。 Private Sub ButtonDoI
我目前正在为 video.js 构建一个插件,它可以在某些断点处将覆盖层呈现在屏幕上。但是,在不启动视频的情况下,我无法单击任何叠加层。我认为我需要禁用播放器上的点击播放功能。 我应该如何禁用/启用
设置剑道网格 selectable: "row", navigatable: true, 允许选择列标题单元格并通过键盘切换其排序状态。如何完全禁用使用键盘选择列标题单元格的功能? 最
我不想卸载code rush。我只是想在不需要的时候有机会将其关闭。 这可能吗? (快速版本)... 最佳答案 首先您应该打开“DevExpress”菜单。默认情况下,它在 CodeRush Xpre
设置: 我正在使用 TinyMCE 的 Angular 包装器来允许我的用户构建自己的电子邮件模板。这些电子邮件会发送给每个用户组织内的多个人员。我创建了自定义工具栏按钮来插入小文本 block [[
我希望下拉菜单在悬停时打开,前提是窗口大于 767 像素。我试图在页面加载和窗口调整大小时调用一个函数,并使用宽度大小条件。 enableHover() 函数仅适用于页面加载,不适用于窗口调整大小。
由于我遇到了一些问题,我正在 .NET Framework 4 中尝试连接池。使用 SQL Profiler,我可以看到每次从连接池中获取连接时,都会执行存储过程 sp_reset_connectio
我避免在我的 swift 代码中收到警告。然而,当谈到 Storyboard要求时,这对我来说有点困难。 所以现在我只想禁用 xcode 显示有关 Storyboard问题的警告。 我尝试了以下方法但
我不是 JavaScript 专家,我目前正在尝试为表单创建一个函数,该函数根据上一页上选择的数字重复相同的字段。 表单字段可能有 1 到 10 行,每行都有一个单选按钮选择,可启用/禁用每一行。 目
我正在尝试使用 CPU2006 运行各种基准测试,以查看各种优化在 gcc 速度方面的作用。我熟悉 -O1、-O2 和 -O3,但听说 -msse 是一个不错的优化。 -msse 到底是什么?我还看到
我是一名优秀的程序员,十分优秀!