উত্তর:
ফ্যালব্যাকের জন্য আরও ভাল এটি:
var alertFallback = true;
if (typeof console === "undefined" || typeof console.log === "undefined") {
console = {};
if (alertFallback) {
console.log = function(msg) {
alert(msg);
};
} else {
console.log = function() {};
}
}
আপনি বিকাশকারী সরঞ্জাম খোলার পরে কনসোল.লগটি কেবল উপলভ্য হবে (এটিকে টগল করার জন্য এফ 12 এটিকে খোলা এবং বন্ধ করার জন্য)। মজার বিষয় হ'ল এটি খোলার পরে আপনি এটি বন্ধ করতে পারবেন, তারপরেও এটি কনসোল.লগ কলগুলির মাধ্যমে পোস্ট করুন এবং আপনি যখন এটি আবার খুলবেন তখন সেগুলি দেখা যাবে। আমি ভাবছি যে এটি এক প্রকারের বাগ এবং ঠিক করা যেতে পারে তবে আমরা দেখতে পাব।
আমি সম্ভবত এই জাতীয় কিছু ব্যবহার করব:
function trace(s) {
if ('console' in self && 'log' in console) console.log(s)
// the line below you might want to comment out, so it dies silent
// but nice for seeing when the console is available or not.
else alert(s)
}
এমনকি আরও সহজ:
function trace(s) {
try { console.log(s) } catch (e) { alert(s) }
}
alert
মন্দ। সতর্কতাগুলি ব্যবহার করার সময় কিছু কোড আলাদা আচরণ করে কারণ ডকুমেন্টটি ফোকাস হারিয়ে ফেলেছে, বাগগুলি নির্ণয় করা আরও শক্ত করে তোলে বা যেখানে আগে ছিল না সেখানে তৈরি করে। এছাড়াও, যদি আপনি ঘটনাক্রমে console.log
আপনার প্রযোজনীয় কোডটিতে একটি রেখে যান , তবে এটি সৌম্যরূপে (ধরে নিলে এটি প্রস্ফুটিত হয় না) - নিঃশব্দে কনসোলে লগ হয়। যদি আপনি দুর্ঘটনাক্রমে alert
আপনার প্রোডাকশন কোডটিতে একটি রেখে যান তবে ব্যবহারকারীর অভিজ্ঞতা নষ্ট হয়ে যায়।
এটি বিভিন্ন উত্তর আমার গ্রহণ। আমি লগ করা বার্তাগুলি দেখতে চেয়েছিলাম, এমনকি যখন তাদের বরখাস্ত করার সময় আইই কনসোলটি খোলা না থাকে, তাই আমি তাদের console.messages
তৈরি করা একটি অ্যারেতে আমি তাদের ধাক্কা দিয়েছি। console.dump()
পুরো লগটি দেখার সুবিধার্থে আমি একটি ফাংশনও যুক্ত করেছি । console.clear()
বার্তা সারি খালি করবে।
এই সমাধানগুলি অন্যান্য কনসোল পদ্ধতিগুলিকেও "পরিচালনা করে" (যা আমি বিশ্বাস করি যে ফায়ারব্যাগ কনসোল এপিআই থেকে সমস্ত উত্সিত হয়েছে )
শেষ অবধি , এই সমাধানটি একটি আইআইএফই আকারে , সুতরাং এটি বৈশ্বিক সুযোগকে দূষিত করে না। ফলব্যাক ফাংশন আর্গুমেন্ট কোডের নীচে সংজ্ঞায়িত করা হয়।
আমি কেবল এটি আমার মাস্টার জেএস ফাইলে ফেলেছি যা প্রতিটি পৃষ্ঠায় অন্তর্ভুক্ত রয়েছে এবং এটি সম্পর্কে ভুলে যাচ্ছি।
(function (fallback) {
fallback = fallback || function () { };
// function to trap most of the console functions from the FireBug Console API.
var trap = function () {
// create an Array from the arguments Object
var args = Array.prototype.slice.call(arguments);
// console.raw captures the raw args, without converting toString
console.raw.push(args);
var message = args.join(' ');
console.messages.push(message);
fallback(message);
};
// redefine console
if (typeof console === 'undefined') {
console = {
messages: [],
raw: [],
dump: function() { return console.messages.join('\n'); },
log: trap,
debug: trap,
info: trap,
warn: trap,
error: trap,
assert: trap,
clear: function() {
console.messages.length = 0;
console.raw.length = 0 ;
},
dir: trap,
dirxml: trap,
trace: trap,
group: trap,
groupCollapsed: trap,
groupEnd: trap,
time: trap,
timeEnd: trap,
timeStamp: trap,
profile: trap,
profileEnd: trap,
count: trap,
exception: trap,
table: trap
};
}
})(null); // to define a fallback function, replace null with the name of the function (ex: alert)
লাইনটি অবজেক্ট var args = Array.prototype.slice.call(arguments);
থেকে একটি অ্যারে তৈরি করে arguments
। এটি প্রয়োজনীয় কারণ আর্গুমেন্টগুলি আসলে অ্যারে নয় ।
trap()
কোনও এপিআই ফাংশনের জন্য একটি ডিফল্ট হ্যান্ডলার। আমি আর্গুমেন্টগুলি message
এমনভাবে পাস করি যাতে আপনি যে কোনও এপিআই কল (কেবল নয় console.log
) পাস হয়ে যাওয়া যুক্তিগুলির একটি লগ পান ।
আমি একটি অতিরিক্ত অ্যারে যুক্ত করেছি console.raw
যা আর্গুমেন্টগুলিকে ঠিক যেমন পাস করেছে তেমন ক্যাপচার করে trap()
। আমি বুঝতে পারি যে args.join(' ')
বস্তুগুলিকে স্ট্রিংয়ে রূপান্তর করা হচ্ছে "[object Object]"
যা কখনও কখনও অযাচিত হতে পারে। ধন্যবাদ bfontaine জন্য পরামর্শ ।
trap
ফাংশন: var args = Array.prototype.slice.call(arguments); var message = args.join(' ');
? আপনি এর মাধ্যমে তর্কগুলি বার্তায় কেন পাস করবেন?
এটি লক্ষণীয় যে console.log
আই 8 এ সত্যিকারের জাভাস্ক্রিপ্ট ফাংশন নয়। এটি apply
বা call
পদ্ধতিগুলি সমর্থন করে না ।
console.log=Function.prototype.bind.call(console.log,console);
এটি কাছাকাছি পেতে।
bind
।
ধরে নিই যে আপনি সতর্ক হওয়ার জন্য কোনও ফালব্যাকের বিষয়ে চিন্তা করছেন না, এখানে ইন্টারনেট এক্সপ্লোরারের ত্রুটিগুলি সমাধানের আরও একটি সংক্ষিপ্ত উপায়:
var console=console||{"log":function(){}};
আমি "কমলা 80" পোস্ট করা পদ্ধতির পছন্দ করি। এটি মার্জিত কারণ আপনি একবার সেট করে এটি ভুলে যেতে পারেন।
অন্যান্য পদ্ধতির জন্য আপনাকে আলাদা কিছু করতে হবে (প্লেইন ব্যতীত অন্য কোনও কিছুকে কল করুন) console.log()
প্রতিবার ), যা কেবল সমস্যার জন্যই জিজ্ঞাসা করছে… আমি জানি যে আমি শেষ পর্যন্ত ভুলে যাব।
ইউটিলিটি ফাংশনে কোড মোড়ানোর মাধ্যমে আমি এটি আরও একধাপ এগিয়ে নিয়ে এসেছি যা আপনি আপনার জাভাস্ক্রিপ্টের শুরুতে একবার কল করতে পারেন, যে কোনও লগিংয়ের আগেই যতক্ষণ না পারে। (আমি এটি আমার সংস্থার ইভেন্ট ডেটা রাউটার পণ্যটিতে ইনস্টল করছি It এটির নতুন অ্যাডমিন ইন্টারফেসের ক্রস ব্রাউজার ডিজাইনকে সহজতর করতে সহায়তা করবে))
/**
* Call once at beginning to ensure your app can safely call console.log() and
* console.dir(), even on browsers that don't support it. You may not get useful
* logging on those browers, but at least you won't generate errors.
*
* @param alertFallback - if 'true', all logs become alerts, if necessary.
* (not usually suitable for production)
*/
function fixConsole(alertFallback)
{
if (typeof console === "undefined")
{
console = {}; // define it if it doesn't exist already
}
if (typeof console.log === "undefined")
{
if (alertFallback) { console.log = function(msg) { alert(msg); }; }
else { console.log = function() {}; }
}
if (typeof console.dir === "undefined")
{
if (alertFallback)
{
// THIS COULD BE IMPROVED… maybe list all the object properties?
console.dir = function(obj) { alert("DIR: "+obj); };
}
else { console.dir = function() {}; }
}
}
/**/console.log("...");
সুতরাং অস্থায়ী কোডটি সন্ধান করা এবং এটি সনাক্ত করা সহজ।
আপনি যদি আপনার সমস্ত কনসোল.লগ কলগুলিতে "অপরিজ্ঞাত" হয়ে থাকেন তবে এর অর্থ সম্ভবত আপনার এখনও একটি পুরানো ফায়ারবগলাইট লোড হয়েছে (ফায়ারবগ.জেএস)। এটি আইই 8 এর কনসোল.লগের সমস্ত বৈধ ফাংশন উপস্থিত থাকলেও ওভাররাইড করবে। যাইহোক আমার সাথে এটি ঘটেছে।
কনসোল অবজেক্টকে ওভাররাইড করে অন্য কোডের জন্য পরীক্ষা করুন।
কনসোলের অভাব রয়েছে এমন যে কোনও ব্রাউজারের জন্য সেরা সমাধানটি হ'ল:
// Avoid `console` errors in browsers that lack a console.
(function() {
var method;
var noop = function () {};
var methods = [
'assert', 'clear', 'count', 'debug', 'dir', 'dirxml', 'error',
'exception', 'group', 'groupCollapsed', 'groupEnd', 'info', 'log',
'markTimeline', 'profile', 'profileEnd', 'table', 'time', 'timeEnd',
'timeStamp', 'trace', 'warn'
];
var length = methods.length;
var console = (window.console = window.console || {});
while (length--) {
method = methods[length];
// Only stub undefined methods.
if (!console[method]) {
console[method] = noop;
}
}
}());
অনেকগুলি উত্তর আছে। এর জন্য আমার সমাধানটি ছিল:
globalNamespace.globalArray = new Array();
if (typeof console === "undefined" || typeof console.log === "undefined") {
console = {};
console.log = function(message) {globalNamespace.globalArray.push(message)};
}
সংক্ষেপে, যদি কনসোল.লগ বিদ্যমান না থাকে (বা এই ক্ষেত্রে খোলা না থাকে) তবে লগটি বিশ্বব্যাপী নেমস্পেস অ্যারেতে সংরক্ষণ করুন। এইভাবে, আপনি কয়েক মিলিয়ন সতর্কতা দিয়ে পরীক্ষিত নন এবং আপনি এখনও বিকাশকারী কনসোল খোলা বা বন্ধ হয়ে আপনার লগগুলি দেখতে পারেন।
যদি (উইন্ডো। কনসোল এবং& ফাংশন '=== টাইপফোন উইন্ডো.কনসোল.লগ) { window.console.log (O); }
window.console.log()
আইই 8 এ পাওয়া যাবে এমনকি যখন console.log()
নেই?
typeof window.console.log === "object"
, নয়"function"
আমি এটি গিথুবে পেয়েছি :
// usage: log('inside coolFunc', this, arguments);
// paulirish.com/2009/log-a-lightweight-wrapper-for-consolelog/
window.log = function f() {
log.history = log.history || [];
log.history.push(arguments);
if (this.console) {
var args = arguments,
newarr;
args.callee = args.callee.caller;
newarr = [].slice.call(args);
if (typeof console.log === 'object') log.apply.call(console.log, console, newarr);
else console.log.apply(console, newarr);
}
};
// make it safe to use console.log always
(function(a) {
function b() {}
for (var c = "assert,count,debug,dir,dirxml,error,exception,group,groupCollapsed,groupEnd,info,log,markTimeline,profile,profileEnd,time,timeEnd,trace,warn".split(","), d; !! (d = c.pop());) {
a[d] = a[d] || b;
}
})(function() {
try {
console.log();
return window.console;
} catch(a) {
return (window.console = {});
}
} ());
আমি উপরে থেকে ওয়াল্টারের পদ্ধতির ব্যবহার করছি (দেখুন: https://stackoverflow.com/a/14246240/3076102 )
আমি সমাধানগুলিতে মিশ্রিত করেছি যা আমি এখানে পেয়েছি https://stackoverflow.com/a/7967670 অবজেক্টসটি সঠিকভাবে প্রদর্শন করতে।
এর অর্থ ফাঁদ ফাংশন হয়ে যায়:
function trap(){
if(debugging){
// create an Array from the arguments Object
var args = Array.prototype.slice.call(arguments);
// console.raw captures the raw args, without converting toString
console.raw.push(args);
var index;
for (index = 0; index < args.length; ++index) {
//fix for objects
if(typeof args[index] === 'object'){
args[index] = JSON.stringify(args[index],null,'\t').replace(/\n/g,'<br>').replace(/\t/g,' ');
}
}
var message = args.join(' ');
console.messages.push(message);
// instead of a fallback function we use the next few lines to output logs
// at the bottom of the page with jQuery
if($){
if($('#_console_log').length == 0) $('body').append($('<div />').attr('id', '_console_log'));
$('#_console_log').append(message).append($('<br />'));
}
}
}
আমি আশা করি এই সহায়ক:-)
এটি IE8 এ কাজ করে। আইপি 8 এর বিকাশকারী সরঞ্জামগুলি এফ 12 টিপুন Open
>>console.log('test')
LOG: test
আমি এই পদ্ধতিটি পছন্দ করি (জ্যাকুরির ডক রেডি ব্যবহার করে) ... এটি আপনাকে এমনকি কনসোল ব্যবহার করতে দেয় ... কেবল ধরা হচ্ছে আপনি পৃষ্ঠাটি লোড করার পরে অর্থাত্ ডিভাইসগুলি খুললে আপনাকে পৃষ্ঠাটি পুনরায় লোড করা দরকার ...
এটি সমস্ত ফাংশনগুলির জন্য অ্যাকাউন্টিং দ্বারা স্লিকারযুক্ত হতে পারে তবে আমি কেবল লগ ব্যবহার করি তাই এটিই আমি করি।
//one last double check against stray console.logs
$(document).ready(function (){
try {
console.log('testing for console in itcutils');
} catch (e) {
window.console = new (function (){ this.log = function (val) {
//do nothing
}})();
}
});
এখানে এমন একটি সংস্করণ রয়েছে যা বিকাশকারী সরঞ্জামগুলি খোলা থাকে এবং যখন বন্ধ থাকে না তখন কনসোলে লগইন করে।
(function(window) {
var console = {};
console.log = function() {
if (window.console && (typeof window.console.log === 'function' || typeof window.console.log === 'object')) {
window.console.log.apply(window, arguments);
}
}
// Rest of your application here
})(window)
apply
পদ্ধতি নেই।
এইচটিএমএলে নিজের কনসোলটি তৈরি করুন .... ;-) এটি ইমপ্রাইড করা যেতে পারে তবে আপনি এটি দিয়ে শুরু করতে পারেন:
if (typeof console == "undefined" || typeof console.log === "undefined") {
var oDiv=document.createElement("div");
var attr = document.createAttribute('id'); attr.value = 'html-console';
oDiv.setAttributeNode(attr);
var style= document.createAttribute('style');
style.value = "overflow: auto; color: red; position: fixed; bottom:0; background-color: black; height: 200px; width: 100%; filter: alpha(opacity=80);";
oDiv.setAttributeNode(style);
var t = document.createElement("h3");
var tcontent = document.createTextNode('console');
t.appendChild(tcontent);
oDiv.appendChild(t);
document.body.appendChild(oDiv);
var htmlConsole = document.getElementById('html-console');
window.console = {
log: function(message) {
var p = document.createElement("p");
var content = document.createTextNode(message.toString());
p.appendChild(content);
htmlConsole.appendChild(p);
}
};
}
console.log
হয় IE8 সেখানে কিন্তুconsole
বস্তু যতক্ষণ না আপনি খোলা DevTools তৈরি করা হয়। অতএব, কল করারconsole.log
ফলে ত্রুটি ঘটতে পারে, উদাহরণস্বরূপ, যদি ডেভ সরঞ্জামগুলি খোলার সুযোগ পাওয়ার আগে এটি পৃষ্ঠা লোডে ঘটে। এখানে বিজয়ী উত্তর এটি আরও বিশদে ব্যাখ্যা করে।