5

让我详细解释一下这个问题。我正在使用 PHP 和 smarty。我op=back从查询字符串中得到一个值。但这不会在每次 PHP 文件运行时发生,所以op=back我必须在什么时候触发特定链接上的单击事件。我的 PHP 文件代码片段如下:

<?php  
  include_once("includes/teacher-application-header.php");

  prepare_request();
  $request = empty( $_GET ) ? $_POST : $_GET ;
  $op = $request['op'];

  $objTeachClassSub = new TeacherClassesSubjects();

  global $teacher_profile_from_session;

  $teacher_id = $teacher_profile_from_session['TEACHER_ID'];

  $teacher_classes_subjects = $objTeachClassSub->GetClassSubjectMappingsbyTeacherId($teacher_id);

$smarty->assign('teacher_classes_subjects', $teacher_classes_subjects); 

  $smarty->assign("op",$op);        
  $smarty->display("teacher-details.tpl");      
?>

现在 smarty 文件中的代码片段如下:

{literal}
<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.9.1/jquery.min.js"></script>
<script type="text/javascript">
</script>
{/literal}
<table width="100%" border="0" align="center" cellpadding="0" cellspacing="0" >
    <tr>
        <td align="left" valign="top">
          <h3>Teacher Details</h3>
        </td>
    </tr>
</table>
<table width="99%" border="0" cellpadding="0" cellspacing="0" class="manage_box" >
    <tr>
      <td>
            <table cellpadding="0" cellspacing="0" border="1" width="100%">
        <tr>
            <td width="25%">
            {if $teacher_classes_subjects}
               {foreach from=$teacher_classes_subjects item="classes_subjects"}
                 <b><a href="#" id="{$classes_subjects.class_id}">{$classes_subjects.class_name}</a></b><br />
                 {if $classes_subjects.class_subjects}
                 <div id="class_subjects_{$classes_subjects.class_id}">
                   {foreach from=$classes_subjects.class_subjects item="class_subjects"}
                        <i><a id ="back" href="chapter_details.php?class_id={$classes_subjects.class_id}&cs_map_id={$class_subjects.cs_map_id}">{$class_subjects.subject_name}</a></i><br />
                   {/foreach}
                 </div>
                 <br />
                 {/if}
               {/foreach}
            {/if}
          </td>  
          <td width="75%">
          {if $chapter_details}
            <ul>
            {foreach from=$chapter_details item=chapter}
            <li><a href="chapter_details.php?op=get_chapter_theory&chapter_id={$chapter.chapter_id}&class_id={$class_id}&cs_map_id={$cs_map_id}&chapter_title={$chapter.chapter_title}">{$chapter.chapter_title}</a></li>
            {/foreach}
            </ul>
          {/if}

          {include file=$file_to_show}
          </td>  aly what is
        </tr>
      </table>
        </td>
    <td align="left" id="subject_container" valign="top">
    </td>
    <td align="left" id="chapter_container" valign="top">
    </td>
  </tr>
</table>

现在我想要实现的是在上面的智能模板文件中编写一个 jQuery 代码,如果 op 值返回(即{op==back}),它将执行。实际上,预期的是op=back点击事件应该在以下链接上触发:

<a id ="back" href="chapter_details.php?class_id={$classes_subjects.class_id}&cs_map_id={$class_subjects.cs_map_id}">{$class_subjects.subject_name}</a>

谁能解释我如何实现这个功能?提前致谢。

4

4 回答 4

1

如果您想在 op==back 时转到特定站点,您应该将其重定向到您的 php 代码中

 if(isset($_GET['op']) && $_GET['op'] == 'back'){
      header('location: yourpath/youurl.php');
 }

请记住在回显任何内容之前执行此操作。

如果您想在设置此选项时触发单击,只需有条件地打印一个带有文档准备好的脚本,如果您使用的是 jQuery,则使用 $('#back').trigger('click'):

 //$go = (isset($_GET['op']) && $_GET['op'] == 'back');
 {if $go}
 <script>
   $(document).ready(function(){
        $('#back').trigger('click');
   });
 </script>
 {/if}

编辑

单击该链接将使浏览器转到另一个页面,除非您使用了诸如 e.preventDefault() 之类的东西。如果您还没有,我建议您使用我提出的第一个解决方案。如果您需要请求到达客户端,然后出于任何原因重定向,或者您执行其他操作,我将使用第二种解决方案。

希望能帮助到你

于 2013-05-31T12:26:24.560 回答
1

我想您最好的选择是将其设置为模板中的隐藏 html 输入,并在文档中的 java 脚本中准备检查该 html 输入的值,然后更改链接的 href 属性

于 2013-05-31T19:58:43.357 回答
0

我想如果你输入标题这应该可以工作

<?php
    if($_GET['op'] == "back"){
        ?>
    <script>
       $(document).ready(function(){
            $('#back').trigger('click');
       });
     </script>
        <?php
        }
?> 

但是如果您需要在页面完全加载后执行此操作,您可以在 JQuery 中设置计时器并在可能 1 秒后执行此 Jquery 脚本

于 2013-05-31T16:15:19.557 回答
0

您可以在纯 JS 中创建一个函数来检索参数的查询字符串值,然后使用它来决定是否应该触发链接单击。

像这样的东西:

function getQueryStringParameter(name) {

    var match = RegExp('[?&]' + name + '=([^&]*)').exec(window.location.search);
    return match && decodeURIComponent(match[1].replace(/\+/g, ' '));
}

var n = getQueryStringParameter('op');
if(n == 'back'){
    $('#back').trigger('click');
}

希望能帮助到你。

于 2013-06-04T03:36:43.013 回答