我正在使用JavascriptMVC(你不需要知道它!)和他们的库“偷”管理文件依赖。
我是javascript的初学者,并且我没有使用命名空间获得的东西;我需要一些由PHP初始化的全局变量,这些变量将在很多其他JS文件中使用,这就是为什么我想让它们全局化:
的index.php
<script type="text/javascript">
steal('jquery', function() {
// here is some jquery specific code
var appletVersion = '<?php echo $appletVersion; ?>';
var baseUrl = '<?php echo BASE_URL; ?>';
});
</script>
在我的JS文件中,我无法访问这两个变量,因为我已经窃取了('jquery',function(){...});而且我猜他们在那个街区之外是不可见的。
test.js
steal('jquery', function(){
console.log(baseUrl); // error
});
答案 0 :(得分:5)
那是因为你的两个变量是传递给steal的函数的本地变量。我的建议是始终将全局变量称为window.globalName
以使您的意图明确。
steal('jquery', function() {
// here is some jquery specific code
window.appletVersion = '<?php echo $appletVersion; ?>';
window.baseUrl = '<?php echo BASE_URL; ?>';
});
// Now you can access window.appletVersion anywhere in your code
请注意,没有必要等待窃取来抓取jQuery来初始化这些变量,因此您可以在外部(在全局范围级别)执行此操作。
<强>命名空间强>
比使用window.globalName
更好的解决方案是在全局级别创建自己的命名空间,以便可以将全局命名空间污染限制为单个对象。这将有助于调试,因为所有代码都不会与全局对象上的其余属性混合。只需console.log它,你就可以看到所有自己的全局变量。
var myNs = {}; // Put all your globals, classes, functions in here to avoid conflicts.
myNs.appletVersion = '<?php echo $appletVersion; ?>' ;
在JS中打印PHP值
如果您在PHP中有一个值并且想要在页面上将其作为JS变量打印,则应使用json_encode
。如果您的字符串嵌入了换行符,引号甚至二进制数据,那么您将不会遇到任何问题。您甚至不必担心类型json_encode
输出始终有效用于JavaScript的内容
myNs.appletVersion = <?php echo json_encode($appletVersion); ?>;
myNs.baseUrl = <?php echo json_encode(BASE_URL); ?>;