将codeigniter环境加载到javascript文件

我在我的javascript文件中使用php而我的.htaccess看起来像</ p>

 &lt; FilesMatch“\ .css $”&gt; 
SetHandler application / x-httpd-php
标题集内容类型“text / css”
&lt; / FilesMatch&gt;

&lt; FilesMatch“ \ .js $“&gt;
SetHandler application / x-httpd-php
标题集内容类型”application / javascript“
&lt; / FilesMatch&gt;
</ code> </ pre>

< p>我现在可以在我的javascript文件中使用php但是codeigniter函数不起作用。例如</ p>

  $('#example')。dataTable({
“bProcessing “:true,
”sAjaxSource“:”&lt;?php $ CI = get_instance(); echo base_url();?&gt;“
});
</ code> </ pre>

给出错误</ p>

 &lt; b&gt;致命错误&lt; / b&gt;:在&lt; b&gt; C:\ xampp \ htdocs \中调用未定义函数get_instance()  _init \资产\ JS \ custom.js&LT; / b个 在线&lt; b&gt; 88&lt; / b&gt;&lt; br /&gt; 
</ code> </ pre>

我想我可能需要以类似于的方式加载codeigniter环境 wordpress require('../wordpress/wp-load.php'); </ code> </ p>

有没有办法以类似的方式加载codeigniter以便codeigniter 函数可用于我的javascript和css文件?</ p>
</ div>

展开原文

原文

I am using php in my javascript file and my .htaccess looks like

<FilesMatch "\.css$">
  SetHandler application/x-httpd-php
  Header set Content-type "text/css"
</FilesMatch>

<FilesMatch "\.js$">
  SetHandler application/x-httpd-php
  Header set Content-type "application/javascript"
</FilesMatch>

I can now use php from within my javascript files but codeigniter functions do not work.For example

$('#example').dataTable( {
        "bProcessing": true,
        "sAjaxSource": "<?php $CI = get_instance(); echo base_url(); ?>"
    } );

gives the error

<b>Fatal error</b>:  Call to undefined function get_instance() in <b>C:\xampp\htdocs\_init\assets\js\custom.js</b> on line <b>88</b><br />

I figured maybe i need to load the codeigniter environment in a way similar to the wordpress require( '../wordpress/wp-load.php' );

Is there a way i can load codeigniter in a similar manner so that codeigniter functions are available to my javascript and css files?.

dongmie3526
dongmie3526 我喜欢这两个用户SO名称:|很酷!
大约 3 年之前 回复
donglu5728
donglu5728 感谢您的评论。我已经重新考虑了这个方法并放弃了所有计划。取而代之的是,我将只通过网址“sAjaxSource”加载我需要的内容:'http://localhost/_init/assets/static_content/arrays.txt”
大约 7 年之前 回复
doulezhi5326
doulezhi5326 您还应确保具体发送无缓存标头以及这些“文件”,以便浏览器不会将CSS缓存为js,认为文件是典型的静态文件。当然,从用户的角度来看,这可能会对您的网站性能产生重大影响,所以我真的会质疑整个方法的开始。例如,在JS片段中没有理由,您无法在可以在静态js文件中引用的sAjaxSource的JS全局范围中定义变量。
大约 7 年之前 回复

1个回答



CI依赖于bootstrap system / core / CodeIgniter.php </ code>来启动应用程序.. </ p>

您可以添加一个魔术文件,以便您访问这些函数。</ p>

解决方案1:</ strong > base_url </ code>问题的最佳解决方案是添加基本标记。</ p>

&lt; base href =”&lt;?php echo base_url();?&gt;“&gt; </ code> </ p>

解决方案2:</ strong>在视图中定义js base_url </ p>

 &lt; script&gt; 
var base_url =“&lt;?php echo base_url();?&gt;”;
&lt; / script&gt;
</ code> </ pre>

在你的js中,你可以访问它.. </ p>

  $('#example')。dataTable({
“bProcessing”:true,
“sAjaxSource “:base_url
});
</ code> </ pre>

您的要求:</ strong> </ p>

I 如果你依赖js和css中的CI函数,那么你的方法应该重新考虑,不过,这是一个可能的解决方案.. </ p>

创建一个控制器 application / controllers / js .php </ code> </ p>

 &lt;?php if(!  defined('BASEPATH'))exit('不允许直接访问脚本'); 

class js扩展CI_Controller {
公共函数索引()
{
$ this-&gt; load-&gt; view(' js');
}
}
</ code> </ pre>

创建视图 application / views / js.php </ code> </ p>

  $('#example')。dataTable({
“bProcessing”:true,
“sAjaxSource”:“&lt;?php echo base_url();?&gt;”
} );
</ code> </ pre>
</ div>

展开原文

原文

CI relies on the bootstrap system/core/CodeIgniter.php to kick off the application..

There isn't a magic file that you can include that will give you access to the functions..

Solution 1: The best solution for your base_url problem is to add a base tag as described by Phil Sturgeon..

<base href="<?php echo base_url(); ?>">

Solution 2: define a js base_url in a view

<script>
   var base_url = "<?php echo base_url(); ?>";
</script>

In your js you would access it like..

$('#example').dataTable( {
    "bProcessing": true,
    "sAjaxSource": base_url
});

What you are asking for:

If you rely on CI functions in your js and css, then your approach should be revisited, nevertheless, here is a possible solution..

Create a controller application/controllers/js.php

<?php if ( ! defined('BASEPATH')) exit('No direct script access allowed');

class js extends CI_Controller {
    public function index()
    {
        $this->load->view('js');
    }
}

Create a view application/views/js.php

$('#example').dataTable( {
    "bProcessing": true,
    "sAjaxSource": "<?php echo base_url(); ?>"
});

duanjin9035
duanjin9035 由于建议的编辑可能会被拒绝,您可以在此处找到第三个解决方案的改进版本。
大约 7 年之前 回复
Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
立即提问
相关内容推荐