rappel à partir de flashembed des outils jquery
-
26-10-2019 - |
Question
Outils jQuery comprend une API flashembed qui accepte de nombreux paramètres. Y at-il un qui accepte la fonction de rappel et les feux après l'état de la réussite de l'événement joueur de charge flash?
playerdiv.flashembed(url+'/VIPlayer.swf','knds_player',300,250,'8.0.0',false,flashVars);
Information:. site officiel
Note: Ceci est possible dans bibliothèque Google swfobject comme ci-dessous:
swfobject.embedSWF(url+'/VIPlayer.swf','knds_player',300,250,'8.0.0',false,flashVars,callBack);
function callBack(event){
event after successful display of code
}
Mais je dois utiliser seulement flashembed. Pouvez-vous me aider ici?
Merci d'avance :)
La solution
La méthode de flashembed a un argument de onFail
qui prend une fonction de rappel en tant que valeur:
$("#flash").flashembed({
src: flashSWF,
version:[10,0],
id:"flashObj",
width: 500,
height: 300,
wmode: "opaque",
cachebusting: "false",
allowscriptaccess: "always",
api: "false",
scale: "noscale",
menu: "false",
onFail: flasherror("#flash")
})
Il se déclenche par inadvertance à la fois le succès et l'échec. Recherchez le caractère ,
de distinguer entre les deux états. En cas d'erreur, il apparaît comme séparateur dans la chaîne de version, comme 11,0
plutôt que 11.0
:
function flashError(domnode, newtext){
function failState()
{
if ($(domnode).html().search(/,/) !== -1) //player failed to load
{
newtext = $(domnode).html(); // store default error string
$(domnode).empty();
$(domnode).append(newtext.replace(/,/g,".")); // replace comma with period
if ($(domnode).hasClass("flashmsg") === false)
{
$(domnode).addClass("flashmsg"); // add class to custom error element
}
}
else
{
//success logic
}
}
// observer constructor
var cursor =
typeof window.hasOwnProperty === "function" ?
window.hasOwnProperty("WebKitMutationObserver")
? new WebKitMutationObserver(startValidation)
: window.hasOwnProperty("MutationObserver")
? new MutationObserver(startValidation)
: false
: false
;
//Use observer event if it exists
if (cursor)
{
//Bind observer event to text child of the dom node
cursor.observe($(domnode).get(0), { childList: true } );
return;
}
//Use mutation event as a fallback
else if (!!document.addEventListener)
{
$(domnode).get(0).addEventListener("DOMNodeInserted", failState, false);
}
//Use readystatechange event for legacy IE
else
{
$(domnode).get(0).addBehavior("foo.htc");
$(domnode).get(0).attachEvent("onreadystatechange", failState);
}
Références