Mediawiki:服务器端使用解析器扩展处理DataTables

时间:2015-11-10 00:42:38

标签: javascript php datatables mediawiki

我正在尝试创建一个MediaWiki解析器扩展,它将创建一个表,解析后的参数将用于dataTables脚本的ajax URL。

$wgHooks['ParserFirstCallInit'][] = 'AllQuesttableFunction';
$wgExtensionMessagesFiles['AllQuestTable'] = __DIR__ . '/_questtable.i18n.php';
function AllQuesttableFunction( &$parser ) {
   $parser->setFunctionHook( 'questtable', 'AllQuestTableParserFunction' );
   return true;
}


function AllQuestTableParserFunction( &$parser, $arg1='', $arg2='', $arg3='' ) {

$tableend = '<br><div class="hbody"><table class="lists list_basicitem width_100p" id="serverTable"><thead><tr><th>Area</th><th>Quest Name</th><th>Min<br>Level</th><th style="width:200px !important">Rewards</th></tr></thead></table><div class="cl"></div></div>';

return array( $tableend, 'noparse' => true, 'isHTML' => true );
}



$wgHooks['ParserBeforeTidy'][] = 'wgAddJquery';

function wgAddJquery(&$parser, &$text) {


  global $addJqueryScripts, $wgLang;
   $code = $wgLang->getCode();
  if ($addJqueryScripts === true) return true;

  $parser->mOutput->addHeadItem(
    '   <script type="text/javascript" language="javascript" src="http://mywiki.com/wiki/extensions/DataTables/DataTables-1.10.0/media/js/jquery.js"></script>
        <script type="text/javascript" language="javascript" src="http://mywiki.com/wiki/extensions/DataTables/DataTables-1.10.0/media/js/jquery.dataTables.js"></script>
        <script type="text/javascript" language="javascript" >
            $(document).ready(function() {
                var dataTable = $("#serverTable").DataTable( {
                    "columnDefs": [
                                {
                                targets: 0,
                                className: \'al\'
                                },
                                {
                                targets: 1,
                                className: \'al\',
                                type: "num-html"
                                },
                                {
                                targets: 2,
                                className: \'ar\'
                                },
                                {
                                targets: 3,
                                className: \'al\'
                                },
                                { targets: \'no-sorting\', orderable: false }
                                ],
                    "processing": true,
                    "language": {
                    "processing": "<img src=\'2.gif\'>"
                    },
                    "serverSide": true,
                    "order": [[ 2, "desc" ]],
                    "ajax":{
                        url :"http://mywiki.com/wiki/extensions/quest_tables/_questtables_ajax.php?lowerlevel=' . $arg1 . '&higherlevel=' . $arg2 . '&race=' . $arg3 . '&lang=en",
                        type: "post",
                    }
                } );
            } );
        </script>'
  );

  $addJqueryScripts = true;

  return true;

}

我使用了此处提供的代码 Mediawiki Extension add Javascript in Header

用于向标题添加脚本但是 首先,它将它添加到每个页面,我只想在具有魔术字的页面上。 第二,它似乎是在AllQuestTableParserFunction之前推动wgAddJquery方式,这意味着我不能在dataTables脚本中使用解析的参数。

TL;博士 有一个页面{{#magicword:arg1 | arg2 | arg3}}。所有3个参数都被解析为一个扩展,其中一个函数创建一个表,第二个将一个脚本添加到标题中,这三个参数作为ajax的url的一部分,并且仅在该页面上。我不需要其他任何地方的脚本。

有任何建议或甚至不可能吗?

1 个答案:

答案 0 :(得分:0)

您应该使用$parser->getOutput()->addModules(...),但这不是重点?

为什么需要ParserBeforeTidy钩子?如果您只想在遇到解析器函数时添加脚本,为什么不从解析器函数处理程序方法中执行此操作?